您的位置 首页 java

Java RPC框架:Java主流的RPC框架了解

RPC 是远程过程调用的简称,广泛应用在大规模分布式应用中,作用是有助于系统的垂直拆分,使系统更易拓展。 JAVA 中的RPC框架比较多,各有特色,广泛使用的有RMI、 Hessian Dubbo 等。RPC还有一个特点就是能够跨语言。

1、RMI(远程方法调用)

JAVA自带的远程方法调用工具,不过有一定的局限性,毕竟是 java 语言最开始时的设计,后来很多框架的原理都基于RMI,RMI的使用如下:

对外接口

public interface IService extends Remote { 
 
 public String queryName(String no) throws RemoteException; 
 

服务实现

import java.rmi.RemoteException; 
import java.rmi.server.UnicastRemoteObject; 
 
// 服务实现 
public class ServiceImpl extends UnicastRemoteObject implements IService { 
 
 /** 
 */ 
 private static final long serialVersionUID = 682805210518738166L; 
 
 /** 
 * @throws RemoteException 
 */ 
 protected ServiceImpl() throws RemoteException { 
 super(); 
 } 
 
 /* (non-Javadoc) 
 * @see com.suning.ebuy.wd.web.IService#queryName(java.lang.String) 
 */ 
 @Override 
 public String queryName(String no) throws RemoteException { 
 // 方法的具体实现 
 System.out.println("hello" + no); 
 return String.valueOf(System.currentTimeMillis()); 
 } 
 
} 
RMI客户端
 
[java] view plain copy
import java.rmi.AccessException; 
import java.rmi.NotBoundException; 
import java.rmi.RemoteException; 
import java.rmi. registry .LocateRegistry; 
import java.rmi.registry.Registry; 
 
// RMI客户端 
public class Client { 
 
 public static void main(String[] args) { 
 // 注册管理器 
 Registry registry = null; 
 try { 
 // 获取服务注册管理器 
 registry = LocateRegistry.getRegistry("127.0.0.1",8088); 
 // 列出所有注册的服务 
 String[] list = registry.list(); 
 for(String s : list){ 
 System.out.println(s); 
 } 
 } catch (RemoteException e) { 
 
 } 
 try { 
 // 根据命名获取服务 
 IService server = (IService) registry.lookup("vince"); 
 // 调用远程方法 
 String result = server.queryName("ha ha ha ha"); 
 // 输出调用结果 
 System.out.println("result from remote : " + result); 
 } catch (AccessException e) { 
 
 } catch (RemoteException e) { 
 
 } catch (NotBoundException e) { 
 
 } 
 } 
} 
RMI服务端
 
[java] view plain copy
import java.rmi.RemoteException; 
import java.rmi.registry.LocateRegistry; 
import java.rmi.registry.Registry; 
 
// RMI服务端 
public class Server { 
 
 public static void main(String[] args) { 
 // 注册管理器 
 Registry registry = null; 
 try { 
 // 创建一个服务注册管理器 
 registry = LocateRegistry.createRegistry(8088); 
 
 } catch (RemoteException e) { 
 
 } 
 try { 
 // 创建一个服务 
 ServiceImpl server = new ServiceImpl(); 
 // 将服务绑定命名 
 registry.rebind("vince", server); 
 
 System.out.println("bind server"); 
 } catch (RemoteException e) { 
 
 } 
 } 
}
 

2、Hessian(基于HTTP的远程方法调用)

基于HTTP协议传输,在性能方面还不够完美,负载均衡和失效转移依赖于应用的负载均衡器,Hessian的使用则与RMI类似,区别在于淡化了Registry的角色,通过显示的地址调用,利用HessianProxyFactory根据配置的地址create一个代理对象,另外还要引入Hessian的Jar包。

3、Dubbo(淘宝开源的基于 TCP 的RPC框架)

基于 Netty 的高性能RPC框架,是阿里巴巴开源的RPC框架,更多内容可查看之前内容.

本文转载于博客园aspirant的博客,如有侵权请联系删除

原文地址:

文章来源:智云一二三科技

文章标题:Java RPC框架:Java主流的RPC框架了解

文章地址:https://www.zhihuclub.com/194764.shtml

关于作者: 智云科技

热门文章

网站地图