首先介绍:
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,