介绍
rpc 全程为 remote procedure call 远程过程调用,当单机的性能满足不了日常业务需求时,我们需要多台服务器组成一个集群,每个集群上部署某一种业务,来满足业务正常的需求。
比如电商下单
- 请求交易接口
- 1.1 请求商品中心,查看商品是否存在
- 1.2 请求优惠中心,冻结优惠
- 1.3 请求库存中心,锁定库存 ....
等等一系列的操作,都需要各个中心协同工作,这时为了满足业务的可靠性,就会每个中心独立部署。运用rpc去调用各个中心的接口。
这时也会存在一个分布式事务的问题,下单接口正常,其他中心接口超时或者挂了,怎么处理? 这里就不展开讲了。
技术点
1.动态代理
client stub 和 server stub
为什么用到这项技术,因为我们的原则上是调用方在调用远程接口时,就像是调用本地接口一样方便。所以怎样才能封装通信细节来实现这个原则呢。
这就引入了动态代理技术,java中有cglib和jdk原生代理等等一些字节码框架。
2.序列化
为了能在网络上传输和接收java对象,我们需要对对象进行序列化和反序列化。
主流的有:Protobuf, Thrift
3.远程通信(NIO)
- 自研
- Netty或者mina,推荐Netty
4.服务注册中心
如何让其他服务器感知你的服务地址,服务状态。 这时候就引出了服务注册中心的概念。服务状态在注册中心里统一维护,如果其他服务有需要,则在中心里面查找对应的地址,再调用即可。
主流的有: zookeeper,Consul,Redis