首先介绍:
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);
}
}
6,测试Java先:java –cp ./Ice.jar:ice_2.jar Demo.Client//把客户端打包成ice_2.jar,