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

相关推荐
Omigeq2 分钟前
1.2.1 - 图搜索算法(以A*为例) - Python运动规划库教程(Python Motion Planning)
开发语言·python·机器人·图搜索算法
资深流水灯工程师3 分钟前
基于Python的Qt开发之Pyside6 串口接收数据被分割的解决方案
开发语言·python·qt
没有bug.的程序员6 分钟前
Java 并发容器深度剖析:ConcurrentHashMap 源码解析与性能优化
java·开发语言·性能优化·并发·源码解析·并发容器
量子炒饭大师40 分钟前
【C++入门】零域终端的虚空指针协议——【nullptr】还在为编译器给NULL匹配为int而头疼?nullptr给予你全新的字面量!
开发语言·c++·nullptr
edisao43 分钟前
一。星舰到底改变了什么?
大数据·开发语言·人工智能·科技·php
阿豪只会阿巴1 小时前
【多喝热水系列】从零开始的ROS2之旅——Day10 话题的订阅与发布1:Python
开发语言·c++·python·ubuntu·ros2
Frank Castle1 小时前
【C语言】详解C语言字节打包:运算符优先级、按位或与字节序那些坑
c语言·开发语言
kk哥88991 小时前
分享一些学习JavaSE的经验和技巧
java·开发语言
2501_940315261 小时前
【无标题】1.17给定一个数将其转换为任意一个进制数(用栈的方法)
开发语言·c++·算法
lagrahhn2 小时前
Java的RoundingMode舍入模式
java·开发语言·金融