简单介绍rpc

介绍

rpc 全程为 remote procedure call 远程过程调用,当单机的性能满足不了日常业务需求时,我们需要多台服务器组成一个集群,每个集群上部署某一种业务,来满足业务正常的需求。

比如电商下单

  1. 请求交易接口
  • 1.1 请求商品中心,查看商品是否存在
  • 1.2 请求优惠中心,冻结优惠
  • 1.3 请求库存中心,锁定库存 ....

等等一系列的操作,都需要各个中心协同工作,这时为了满足业务的可靠性,就会每个中心独立部署。运用rpc去调用各个中心的接口。

这时也会存在一个分布式事务的问题,下单接口正常,其他中心接口超时或者挂了,怎么处理? 这里就不展开讲了。

技术点

1.动态代理

client stub 和 server stub

为什么用到这项技术,因为我们的原则上是调用方在调用远程接口时,就像是调用本地接口一样方便。所以怎样才能封装通信细节来实现这个原则呢。

这就引入了动态代理技术,java中有cglib和jdk原生代理等等一些字节码框架。

2.序列化

为了能在网络上传输和接收java对象,我们需要对对象进行序列化和反序列化。

主流的有:Protobuf, Thrift

3.远程通信(NIO)

  1. 自研
  2. Netty或者mina,推荐Netty

4.服务注册中心

如何让其他服务器感知你的服务地址,服务状态。 这时候就引出了服务注册中心的概念。服务状态在注册中心里统一维护,如果其他服务有需要,则在中心里面查找对应的地址,再调用即可。

主流的有: zookeeper,Consul,Redis

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值