ICE java 实例


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

猜你喜欢

转载自wwangcg.iteye.com/blog/1452799
ice