千家信息网

大数据架构中RPC传输是什么

发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,大数据架构中RPC传输是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。RPC(Remote ProcedureCall),即远程
千家信息网最后更新 2025年01月23日大数据架构中RPC传输是什么

大数据架构中RPC传输是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

RPC(Remote ProcedureCall),即远程过程调用,通过网络实现两个服务器之前的调用,RPC是跨越传输层和应用层。

RPC的调用过程:

客户端端发起一个RPC请求,本地调用client stub负责将调用的接口、方法和参数按照事先约定好的协议进行序列化,然后由RPC框架的RPCRuntime实例通过socket传输到远程服务器上,远程服务器端RPCRuntime收到实例后在通过server stub进行反序列化,发起最终的method调用。

比较优秀的RPC开源框架:

国内Dubbo、Motan,国外Thrift、gRPC

从以下方面理解RPC的实现原理:

1、动态代理:代理就是要做一件事,不用亲自去做,找一个代理代做,动态是指可以动态指定执行的方法及任务数。

2、反射:是指计算机程序在运行时可以访问、检测和修改它本身状态或行为的一种能力。传入远程服务名和方法名,通过反射自动定位到需要被调用的方法,再传入入参,从而进行RPC调用。

3、序列化:将内存中的数据体转换为字节流,反序列化是将字节流转换为数据体。

4、网络编程:RPC一般以TCP协议为基础。

服务RPC请求异常的定位方法:

第1步、分析网络情况,查看是否延迟严重,是否存在TCP重传。

第2步、分析服务端和调用端的运行情况,查看是否压力较大,比如CPU使用率、CPU负载、内存占用大小等

第3步、查看传输对象是否很大很复杂,这对序列化影响很大。

第4步、如果服务端有队列,可以试着减少队列,或者改为固定线程池,减少线程池数量。

第5步、控制CPU不用使用太高,尽量不要超过80%,有个计算公式(核数*7)然后去百分比,eg:4c的容器,那么2.8%的使用率属于正常水平,当达到80%可能有线程阻塞。

关于大数据架构中RPC传输是什么问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注行业资讯频道了解更多相关知识。

0