RPC草稿

总结

(1)id生成器:AtomicInteger idGenerator = new AtomicInteger();Integer id = idGenerator.incrementAndGet();
(2)@RestController=@Controller+@ResponseBody
(3)@Autowired 用于构造器注入,构造器注入好处有:提前初始化,不能修改,比字段型注入好一些。
(4)@PostMapping("/") 用于接受请求 ,PostMapping("") 接受post请求时传入的参数可以通过(@RequestParam String name)这个注解传递给name
(5)springboot多模块项目 打jar包时,< build >要放在启动类所在模块;打war包时要在启动类所在模块设置webapp/WEB-INF/web.xml来满足maven的web插件的规范才可以。java -jar xxx.jar,java -jar xxx.war就可以运行项目

RPC:Remote Procedure Call,远程过程调用。有返回值的叫函数,无返回值的叫过程。是分布式系统常见的一种通信方法,从跨进程到跨物理机已经有几十年历史,其实是一种非常古老的技术,也有很多成熟的框架可以直接用,尤其在大数据领域分布式很广泛。

跨进程交互形式:RESTful接口,WebService,HTTP,基于DB做数据交换,基于MQ做数据交换,以及RPC。既然有了通用的HTTP,为啥还需要RPC?因为HTTP类似于普通话,通用广泛,但有时可能不如方言(RPC)来的方便。

依赖中间件做数据交互:系统A ----->数据存储(DB,MQ,Redis)<---- 系统B。MySQL,RabbitMQ,Kafka,Redis。系统A,B之间是异步的。

直接交互:客户端 ----> HTTP,RPC,WS ----> 服务端。RESTful, WebService, RPC,HTTP。 同步执行,Server速度会直接影响Client, 对响应速度要求比较高。因为中间件中数据可以长时间存储,下游系统想什么消费都是自己说了算,数据可以积压。但直接交互中,客户端会一直等待服务端返回。

在RPC中:Server:Provider、服务提供者;Client:Consumer、消费者;Stub:存根、服务描述,初步把它理解为一个java接口吧。

那RPC相比其他直接交互形式的优势是什么?在RPC中,可以像调用本地方法那样,调用远程方法。

服务治理,就是RPC调用再加上一些对服务的综合管理;比如说给它加上一个注册中心,加上服务的监控,能够对服务做降解,做权限控制。

核心原理(整体架构):Server:Provider,暴露服务,服务提供方;Client:Consumer,服务消费,调用远程服务;Registry:服务注册与发现。三者涉及到了观察者模式,被观察者,观察者,一对多的通知。但是服务注册中心也不是必须的,可以把Server的地址和暴露的服务直接写死在Client。

技术栈:
java基础,maven,反射;
动态代理(生成client存根实际调用对象);
序列化(java对象与二进制数据互转),fastjson,序列化-java对象转为二进制数组,反序列化-二进制数组转换为java对象,因为java中字符串底层就是byte数组,byte数组内存的就是二进制数,所以fastjson可以用于java对象与二进制数据的转换;
网络通信(传输序列化后的数据),jetty,URLConnection。这个案例中用的是HTTP传输,Server端会用到jetty,把它嵌入到我们自己的程序当中,客户端就用JDK自带的URLConnection。其实在RPC中,基本上都是使用TCP长连接来实现通信的,而我们这里采用的HTTP其实也是有一定应用场景的,一面是比较简单,另一方面假如说我们已经有了一个HTTP服务,但是又想开放这个RPC服务,同时不想去多开一个网络端口(涉及到安全),这个时候直接走HTTP是比较好的。虽然TCP长连接是RPC主流,但是用HTTP也不影响我们对RPC底层实现的理解。
其实java中网络编程是比较难的,比如优秀的框架netty,不过不要担心,这个例子接下来开发的RPC框架对网络通信这块进行了一层抽象,也就是我们可以很方便地把底层的HTTP换成这些框架,或者是直接使用Socket,又或者是使用java的NIO来实现。

Jetty 是一个开源的servlet容器,它为基于Java的web容器,例如JSP和servlet提供运行环境。Jetty是使用Java语言编写的,它的API以一组JAR包的形式发布。开发人员可以将Jetty容器实例化成一个对象,可以迅速为一些独立运行(stand-alone)的Java应用提供网络和web连接。

实战篇(代码实现)
第一步:创建工程、制定协议(Server与Client间的交互协议)、通用工具方法
第二部:实现序列化模块
第三步:实现网络模块(根据RPC的通信场景对网络通信进行一层抽象)
第四步:实现Server模块(暴露服务,同时对服务做管理)
第五步:实现Client模块(用到动态代理,在代理对象内部通过网络通信与Server进行交互)
第六步:gk-rpc使用案例(上面完成的框架,在这里做一个小例子,加深对框架的理解)

不足:
1:安全性:http改为https;序列化进行加密;网络连接时进行验证;
2:服务端处理能力:jetty,线程池相关
3:注册中心:有最好,起到对server地址的注册,client可以去注册中心自动地发现服务地址
4:集成能力:比如怎么和springboot集成

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值