[b]
首先介绍:
ICE是一个面向对象的中间件平台。从根本上讲,这意味着ICE提供了一些工具、API和库用以开发面向对象的客户端-服务器的应用程序。ICE应用程序适合于用在各种异构的环境中:客户端和服务器可以用不同的语言编写,能够运行在不同的操作系统、不同体系结构的机器上,可以用不同的网络技术进行通讯(大概10种以上)。这些程序的源代码可以在不同的开发环境之间移植。
在我看来其实是dcom和CORBA的封装。他和gearman和thrift类似。
一:
首先确保各个编译器安装成功。检测
Slice2java ,slice2cpp,slice2C#,slice2py,slice2vb,slice2rb等
开放端口默认开放10000
二编写Ice脚本:
module Demo{
interface Printer{
string printString(string s);
};
};
运行slice2java Demo.ice;
三,编写servant类的PrinterI:
public class PrinterI extends _PrinterDisp{
public String printString(String s, Current __current) {
// TODO Auto-generated method stub
StringBuilder sb=new StringBuilder(s);
s=sb.reverse().toString();
return s;
}
}
编写Server:
public class Server {
public static void main(String[] args) {
int status = 0;
Ice.Communicator ic = null;
try {
ic = Ice.Util.initialize(args);// 初始化参数
Ice.ObjectAdapter adapter = ic.createObjectAdapterWithEndpoints(
"simplePrinterAdapter", "default -p 10000");// 创造对象适配器
Ice.Object objcet = new PrinterI();// 创建servant对象
adapter.add(objcet, Ice.Util.stringToIdentity("simplePrinter"));// 适配器添加一个新的servant,给servant对象取个名字
adapter.activate();
System.out.println("connection success");
ic.waitForShutdown();
} catch (Ice.LocalException e) {
e.printStackTrace();
status = 1;
} catch (Exception e) {
System.err.print(e.getMessage());
status = 1;
} finally {
if (ic != null) {
ic.destroy();
}
}
System.exit(status);
}
}
四,运行服务器端:在windows下建立的Java工程 打成ice_1.jar包放到Linux上运行
命令:java –cp ./Ice.jar:ice_1.jar Demo.Server//注意Ice.jar包放到ice_*.jar的同一个目录,(特别注意不要再按ctr+c在当前窗体运行客户端,按ctr+c它会中断服务器,NND这里把握搞得郁闷)
五,编写客户端(Java和PHP版)
Java版:
public class Client {
/**
* @param args
*/
public static void main(String[] args) {
int status = 0;
Ice.Communicator ic = null;
try {
ic = Ice.Util.initialize(args);
Ice.ObjectPrx base = ic.stringToProxy("simplePrinter:default -p 10000" +
"");
PrinterPrx printer = PrinterPrxHelper.checkedCast(base);
if (printer == null) {
System.out.println("invalid proxy");
}
String out = printer.printString("I love you");
System.out.println(out);
} catch (Ice.LocalException e) {
// TODO: handle exception
e.printStackTrace();
status = 1;
} catch (Exception e) {
System.err.print(e.getMessage());
status = 1;
} finally {
if (ic != null) {
ic.destroy();
}
}
System.exit(status);
}
}
PHP版:
先确保PHP安装成功再在PHP.ini文件下增加
1.extension=IcePHP.so
ice.profiles = /etc/ice.prop//注意要 先建立ice.prop文件
2.在ice.prop里增加:[demo]
ice.slice=/options/demo.ice//注意demo.ice放置的目录
3.PHP:
<?php
ini_set("display_errors","1");
global $ICE;
Ice_loadFile("demo");
try {
$Base=$ICE->stringToProxy("SimplePrinter:default -p 10000");
$Manager=$Base->ice_checkedCast("::Demo::Printer");
$Properties=$Manager->printString("helloworld");
echo $Properties;
}
catch( Exception $e ) {
print_r($e);
}
?>
6,测试Java先:java –cp ./Ice.jar:ice_2.jar Demo.Client//把客户端打包成ice_2.jar,
测试:PHP,把PHP文件放到PHP环境下 在浏览器访问。
[/b]
分享到:
相关推荐
### Ice的安装步骤和运行Demo:构建Eclipse下的分布式计算环境 #### 1. 中间件的概念及作用 中间件是一种系统软件,位于硬件和操作系统之上,为应用软件的开发和运行提供支持,使得应用软件能相对独立于底层硬件和...
客户和服务器通信双方可以用不同的编程语言编写,目前最新的版本支持的语言包括C++,.NET,Java,Python,Objective-C,Ruby,PHP and ActionScript。客户和服务器可以分别部署,可以运行在不同的操作系统和机器架构...
在`Hello.ice`文件中,我们定义了一个名为`Demo.Hello`的接口,包含几个方法如`sayHello`、`returnHello`、`test`和`shutdown`。这些方法的特性,如`idempotent`和`cpp:const`,是用来指导编译器生成对应语言的代码...
1. **ICE(冰)中间件**:ICE是ZeroC公司提供的一种跨平台、跨语言的分布式计算框架,支持多种编程语言,包括C++、Java、Python、PHP等。它提供了一种类型安全、高效的通信机制,使得不同语言的组件能够像在同一进程...
The ice-demos repository provides sample programs for Ice. The sample programs are grouped by programming language: * [C++11](./cpp11) * [C++98](./cpp98) * [C#](./csharp) * [Java](./java) * [Java-...
中指定ice.slice变量,指向ICE的slice文件,如`ice.slice=D:/ice/Ice-3.3.1-VC60/demophp/Ice/hello/Hello.ice`。 3. **解决错误**:如果出现错误,检查ICE库路径是否已正确添加到环境变量,并确保所有依赖项都已...