RPC框架--实现一个非常简单的RPC调用

java启动tomcat服务器,作为服务器的提供者

在这个项目中rpc服务端在tomcat服务器中启动,下面是RPC类的启动函数,初始化了一个tomcat配置,启动服务器

public class HttpServer {

public void start(String hostname, Integer port) {

//读取用户的配置 server.name = netty

Tomcat tomcat = new Tomcat();

Server server = tomcat.getServer();

Service service = (Service) server.findService("Tomcat");

Connector connector = new Connector();

connector.setPort(port);

Engine engine = new StandardEngine();

engine.setDefaultHost(hostname);

Host host = new StandardHost();

host.setName(hostname);

String contextPath = "";

Context context = new StandardContext();

context.setPath(contextPath);

context.addLifecycleListener(new Tomcat.FixContextListener());

host.addChild(context);

engine.addChild(host);

service.setContainer(engine);

service.addConnector(connector);

tomcat.addServlet(contextPath, "dispatcher", new DispatcherServlet());

context.addServletMappingDecoded("/*", "dispatcher");

try {

tomcat.start();

tomcat.getServer().await();

} catch (LifecycleException e) {

e.printStackTrace();

}

};

}

provider处理RPC请求

在启动的tomcat服务器中添加一个handler服务,handler根据需要调用哪个方法,结合方法参数进行调用返回处理结果

但是这种处理方式过于简单粗暴了,我们每次添加服务时都需要provider去手动配置。因此,在这里我们需要实现一个服务注册中心,当provider服务启动时,他会自动把服务信息添加到注册中心,这样就无需手动地去配置,在项目中,我们一开始用一个本地的Map去实现注册信息的存储

在provider启动时自动进行服务地注册和发现,用户通过invocation,传入服务、方法名、参数调用

动态代理优化消费者服务调用

动态代理实现是消费者程序传入类名通过动态代理拿到服务对象,然后传入方法名调用

在动态代理基础上,我们还要实现服务的注册与发现

服务注册与服务发现:

用map保存注册的服务信息,map的key是提供的服务名称,value是URL的列表我们一开始的实现方法是在服务端保存一个Map用来保存已经注册的服务和它对应的接口,然后consumer从map中拿。但上面的实现有很大的问题,provider和consumer是两个不同的进程,注册时服务实例信息只存入了provider的map中,而consumer进程的map是空的。因此,具体实现时,需要借助中间件存储服务实例信息map类实现

provider进程在开启时将服务实例注册到map中

consumer进程通过动态代理拿到url信息

要解决上面的问题,我们需要借助redis、zookeeper等中间件实现服务注册中心。以redis为例,每次调用服务时,我们都需要去redis中查询服务信息,rpc服务比较耗时。因此,我们需要在客户端借助本地缓存保存服务信息。但我们会发现,如果服务端存在一些节点挂了或者新增节点等需要更新map的URL信息的话,会出现缓存过期的情况。在这里,我们采用本地文件的方式做了个简易实现

负载均衡实现:

原来的服务中心,一个方法只对应于一个一个URL存储,修改注册和发现的存储格式,但现在我们将一个方法对应的URL保存成数组,实现一个LoadBalancer类,当一个URL出问题时,去尝试访问其他没访问过的URL

我们可以在动态代理功能内加入下面代码,实现服务重试和容错

实现服务的mock功能

相关推荐
克里斯蒂亚诺更新22 分钟前
https写一个定位当前位置获取经纬度的H5页面
css·网络协议·https
北京耐用通信1 小时前
耐达讯自动化Profibus总线光纤中继器:破解石油化工分析仪器通讯难题
网络·人工智能·科技·物联网·网络协议·自动化·信息与通信
e***98572 小时前
TCP/IP协议栈全解析:从基础到未来
网络·网络协议·tcp/ip
firstacui2 小时前
Keepalived+nginx+tomcat
nginx·tomcat·firefox
乾元2 小时前
构建你的个人「网络 AI 实验室」——硬件、模拟器与数据集清单
运维·网络·人工智能·网络协议·架构
深圳市恒讯科技2 小时前
在带有HTTPS的VPS上安装和部署n8n的最简单方法
网络协议·http·https
YYYing.4 小时前
【计算机网络 | 第四篇】路由与NAT技术
运维·服务器·网络·网络协议·计算机网络
科技块儿4 小时前
【游戏防外挂】同一IP多账号登录?IP地址查询定位快速识别工作室
网络协议·tcp/ip·游戏
前端达人4 小时前
WebSocket vs SSE深度对比分析
网络·websocket·网络协议
守城小轩5 小时前
深度解析 Firefox 144+ 编译架构(五)深入解析 Bootstrap 引导模式
firefox·浏览器自动化·指纹浏览器·浏览器开发