当前位置: 首页 > article >正文

Go-RPC框架分层设计

本地函数调用:

远程函数调用RPC :Remote Procedure Calls

网上商城和支付服务并不在同一个服务器 所以得远程函数调用
需要解决的问题:
1.函数映射(映射到正确的函数 要付款而不是退款 每个函数得有自己的ID 才能找到)
2.数据转换成字节流(本地的只需要压栈 并不需要别的)
3.网络传输(怎么保证高效稳定传输呢)

一次RPC的完整过程

1.IDL文件:使用中立的方式来描述接口 不同的语言之间也可以相互通信了
2.生成代码:通过编译器工具把IDL文件转换为语言对应的静态库
3.编解码:也叫序列化与反序列化 从内存中表示–>字节序列 这就是一次编码
4.通信协议:规范传输内容和格式
5.网络传输:TCP/UDP

RPC的好处

1.单一职责了 不同的服务可以用不同的语言进行开发 比如视频-直播-商城-通知-支付等等
2.可扩展性强
3.故障可以隔离 整体可靠性增加了 高内聚低耦合

RPC分层设计-以Thrift为例

在这里插入图片描述在上图的generated code阶段:
client和server会依赖同一份IDL文件 然后生成不同语言的CodeGen(Golang C++ Java)

在这个编解码层:有数据格式:语言特定的格式-文本格式-二进制编码
而Thrift和Protobuf就是二进制编码格式 跨语言 高性能 比较常见

而现在谈的Thrift用的编码是TLV编码 tag-length-value
在这里插入图片描述上图所示 这个是自己写 然后TLV编码会把它编程二进制的BinaryProtocol
而这个编解码层:必须得有兼容性-通用性-性能好

协议层

网络通信层:Sockets API 这个介于应用层和传输层 传输层是TCP UDP
Sockets流程:bind listen accept read write


http://www.kler.cn/a/396209.html

相关文章:

  • 政务数据治理专栏开搞!
  • windows tomcat 报错后如何让窗口不闪退
  • 求A/B高精度值
  • 【Qt聊天室客户端】消息功能--发布程序
  • LaTeX之四:如何兼容中文(上手中文简历和中文论文)、在win/mac上安装新字体。
  • A029-基于Spring Boot的物流管理系统的设计与实现
  • AndroidStudio 获取 Git 提交次数和编译时间
  • ubuntu将firewall-config导出为.deb文件
  • [项目代码] YOLOv5 铁路工人安全帽安全背心识别 [目标检测]
  • 深度神经网络DNN反向传播BP算法公式推导
  • Flume1.9.0自定义Sink组件将数据发送至Mysql
  • 基于OpenCV的图片人脸检测研究
  • 【Java】设计模式——工厂模式
  • emulator总结
  • 26. 智能指针
  • Py2Neo 库将 Json 文件导入 Neo4J
  • 新能源汽车磁集成技术的机遇与瓶颈
  • 比特大陆/算能科技嵌入式面试题及参考答案
  • 商业智能BI如何零编码对接低代码数据模型?
  • 从依托指标字典到 NoETL 自动化指标平台,指标口径一致性管理的进阶
  • union介绍及使用
  • leetcode104:二叉树的最大深度
  • KkFileView4.1.0部署文档--linux
  • 基于.NET 9实现实时进度条功能:前后端完整示例教程
  • Hutool:代码便捷之道
  • 【安全科普】NUMA防火墙诞生记