一个通用的网络RPC框架,它应该包括如下功能:
QiuRPC特点
QiuRPC是一个采用JAVA实现的小巧的RPC框架,一共3K多行代码,实现了RPC的基本功能,开发者也可以自定义扩展,可以供大家学习探讨或者在小项目中使用,目前QiuRPC具有如下特点:
系统待改进点
2. 目前用的是反射和java代理实现的服务端存根和客户端代理,为了提高性能,可以把这些用javassit,asm等java字节码工具实现 3. 增加一些监控功能,为了增强服务的稳定性和服务的可控性,监控功能是不可或缺的 4. 目前应用协议采用的是最简单的协议,仅仅一个魔数+序列化的实体,这些需要增强,比如增加版本号以解决向前兼容性 5. 增加High availability的一些手段,目前只有负载均衡,其他的比如failover,多副本策略,开关降级等,过载保护等需要自己实现
示例:
1. 编写服务端接口 public interface IServer1 { public String getMsg(); public Message echoMsg(String msg); public Message echoMsg(int msg); } 2. 编写服务端实现类 @ServiceAnnotation(name="myserver1") public class MyServer1 implements IServer1{ private static final Log log=LogFactory.getLog(MyServer1.class); public String getMsg() { log.info("getMsg echo"); return "Hello"; } @Override public Message echoMsg(String msg) { Message result=new Message(); result.setMsg(msg); result.setData(new Date()); return result; } @Override public Message echoMsg(int msg) { Message result=new Message(); result.setMsg("int:"+msg); result.setData(new Date()); return result; } } 3. 启动服务 public static void main(String[] args) { RpcServerBootstrap bootstrap=new RpcServerBootstrap(); bootstrap.start(8080); } 4. 编写客户端调用代码 public class Client1 { public static void main(String[] args) { try { final IServer1 server1=RpcClientProxy.proxy(IServer1.class,"server1" , "myserver1"); long startMillis=System.currentTimeMillis(); for(int i=0;i<10000;i++) { final int f_i=i; send(server1,f_i); } long endMillis=System.currentTimeMillis(); System.out.println("spend time:"+(endMillis-startMillis)); } catch (Throwable e) { e.printStackTrace(); } } public static void send(IServer1 server1,int f_i) { Message msg = null; try { //由于客户端配置的async="true",我们用异步方式来获取结果,如果是同步方式,直接msg=server1.echoMsg(f_i)即可 server1.echoMsg(f_i); Future future = RpcContext.getContext().getFuture(); msg=future.get(); System.out.println("msg:"+msg.getMsg()+","+msg.getData()); } catch(Throwable e) { e.printStackTrace(); } } } 5. 编写客户端配置文件 <application maxThreadCount="100"> <service name="server1" connectStr="127.0.0.1:9090;127.0.0.1:8080" maxConnection="100" async="true"></service> </application>