【文件属性】:
文件名称:zero ICE快速入门java版
文件大小:970KB
文件格式:PDF
更新时间:2020-10-10 04:26:58
zero ICE rpc 快速 入门
zero ICE快速入门文档, ice是最优秀的rpc框架。
4、开发服务端代码如下
步骤一:编写Servant类即带有Disp的存根文件也就是说继承_HelloWorldDisp 这个类,这个类是个抽象类定义如下:
public abstract class _HelloWorldDisp extends Ice.ObjectImpl implements HelloWorld{}
servant类是ice所定义的接口,在服务器端的实现类。我们在该类中可以编写服务器端对请求的具体处理。
代码如下:
package myHelloWorld.server;
import Ice.Current;
import myHelloWorld._HelloWorldDisp;
public class HelloWorld_gaojs extends _HelloWorldDisp{
private static final long serialVersionUID = 1L;
public void say(String s, Current __current) {
System.out.println("Hello World!"+" the string s is " + s);
}
}
步骤二:创建远程的服务器类
package myHelloWorld.server;
public class ServerStart {
/**
* @param args
*/
public static void main(String[] args) {
int status = 0;
// Communicator实例,是ice run time的主句柄
Ice.Communicator ic = null;
try {
// 调用Ice.Util.Initialize()初始化Ice run time
System.out.println("初始化ice run time...");
ic = Ice.Util.initialize(args); // args参数可传可不传
// 创建一个对象适配器,传入适配器名字和在10000端口处接收来的请求
System.out.println("创建对象适配器,监听端口10000...");
Ice.ObjectAdapter adapter = ic.createObjectAdapterWithEndpoints(
"SimplePrinterAdapter", "default -p 10000");
// 实例化一个PrinterI对象,为Printer接口创建一个servant
System.out.println("为接口创建servant...");
Ice.Object object = new HelloWorld_gaojs();
// 调用适配器的add,告诉它有一个新的servant,传递的参数是刚才的servant,这里的“gaojs”是Servant的名字
System.out.println("对象适配器加入servant...");
adapter.add(object, Ice.Util.stringToIdentity("gaojs"));
// 调用适配器的activate()方法,激活适配器。被激活后,服务器开始处理来自客户的请求。
System.out.println("激活适配器,服务器等待处理请求...");
adapter.activate();
// 这个方法挂起发出调用的线程,直到服务器实现终止为止。或我们自己发出一个调用关闭。
ic.waitForShutdown();
} catch (Ice.LocalException e) {
e.printStackTrace();
status = 1;
} catch (Exception e) {
e.printStackTrace();
status = 1;
} finally {
if (ic != null) {
ic.destroy();
}
}
System.exit(status);
}
}