- 授权协议: GPL
- 开发语言: Java
- 操作系统: 跨平台
- 软件首页: http://git.oschina.net/sandyfog/zrpc
- 软件文档: http://git.oschina.net/sandyfog/zrpc
软件介绍
ZRPC
基于Netty实现的RPC框架
服务端
RpcServer server = new RpcServer("127.0.0.1",1234);
HelloServiceImpl impl = new HelloServiceImpl();
server.export(HelloService.class, impl);客户端
RpcClient client = new RpcClient("127.0.0.1",1234);
HelloService service = client.refer(HelloService.class);
//同步调用
System.out.println(service.hello("test rpc"));异步调用
默认的远程调用都是同步的,发起异步调用需要设置RpcContext.setAsync(true),异步调用有两种方式:Future方式、callback方式,可以单独使用也可以混合使用
Future方式
RpcClient client = new RpcClient("127.0.0.1",1234);
HelloService service = client.refer(HelloService.class);
RpcContext ctx = RpcContext.getContext();
ctx.setAsync(true);
String obj=service.hello("test rpc");
System.out.println(obj==null);
Future<String> f =ctx.getFuture();
System.out.println(f.get());callback方式
RpcClient client = new RpcClient("127.0.0.1",1234);
HelloService service = client.refer(HelloService.class);
RpcContext ctx = RpcContext.getContext();
ctx.setAsync(true);
ctx.setCallback(new Callback() {
@Override
public void onSuccess(Object result) {
System.out.println("success "+ result);
}
@Override
public void onError(Throwable thr) {
System.out.println("error");
thr.printStackTrace();
}
});
String obj=service.hello("test rpc");
System.out.println(obj==null);单向调用
单向调用是一种特殊类型的异步调用,意味着客户端对本次调用不期待服务端的响应结果。实际上服务端对于单向调用请求也不会作出响应。对于特定场景单向调用性能更好,但并不那么可靠。
//单向调用
RpcContext ctx = RpcContext.getContext();
ctx.setOneway(true);
System.out.println(service.hello("test rpc")==null);
多处理器编程的艺术
(美)Maurice Herlihy、(美)Nir Shavit / 机械工业出版社 / 2013-2 / 79.00元
工业界称为多核的多处理器机器正迅速地渗入计算的各个领域。多处理器编程要求理解新型计算原理、算法及编程工具,至今很少有人能够精通这门编程艺术。 现今,大多数工程技术人员都是通过艰辛的反复实践、求助有经验的朋友来学习多处理器编程技巧。这本最新的权威著作致力于改变这种状况,作者全面阐述了多处理器编程的指导原则,介绍了编制高效的多处理器程序所必备的算法技术。了解本书所涵盖的多处理器编程关键问题将使在......一起来看看 《多处理器编程的艺术》 这本书的介绍吧!
