惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

H
Help Net Security
J
Java Code Geeks
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
H
Hackread – Cybersecurity News, Data Breaches, AI and More
V
Visual Studio Blog
G
Google Developers Blog
V
V2EX
The Register - Security
The Register - Security
博客园 - 三生石上(FineUI控件)
云风的 BLOG
云风的 BLOG
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
博客园_首页
S
SegmentFault 最新的问题
博客园 - Franky
Martin Fowler
Martin Fowler
Stack Overflow Blog
Stack Overflow Blog
A
About on SuperTechFans
人人都是产品经理
人人都是产品经理
aimingoo的专栏
aimingoo的专栏
罗磊的独立博客
C
Check Point Blog
MyScale Blog
MyScale Blog
T
The Blog of Author Tim Ferriss
MongoDB | Blog
MongoDB | Blog
The GitHub Blog
The GitHub Blog
Last Week in AI
Last Week in AI
Microsoft Azure Blog
Microsoft Azure Blog
IT之家
IT之家
F
Fortinet All Blogs
Jina AI
Jina AI
P
Proofpoint News Feed
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
阮一峰的网络日志
阮一峰的网络日志
B
Blog
L
LangChain Blog
月光博客
月光博客
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
宝玉的分享
宝玉的分享
博客园 - 【当耐特】
T
Tailwind CSS Blog
酷 壳 – CoolShell
酷 壳 – CoolShell
Microsoft Security Blog
Microsoft Security Blog
WordPress大学
WordPress大学
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
B
Blog RSS Feed
博客园 - 聂微东
Hugging Face - Blog
Hugging Face - Blog
M
MIT News - Artificial intelligence
GbyAI
GbyAI

博客园 - 李潘

我们为什么需要分布式系统? 怎么算是在工作中负责? 怎么更好的沟通? 怎么用工作邮件? 为工作排好优先级 聊聊数据压缩 怎么使用硬件同步原语替代锁? 怎么正确使用锁? 聊聊缓存 为什么Kafka的性能那么好? 怎么避免服务内存溢出? 怎么选择数据序列化方案? 怎么利用异步设计提升系统性能? 怎么处理消息积压问题? 怎么处理消息重发的问题? 怎么做才能不丢消息? 怎么用消息队列实现分布式事务? 聊聊消息队列中的基础概念 我们要选择哪个消息队列产品?
应用程序之间的通信传输协议
李潘 · 2023-03-14 · via 博客园 - 李潘

传输协议是应用程序之间对话的语言,涉及传输协议,并没有太多规范和要求,只要通信双方的应用程序都能正确处理这个协议,没有歧义就可以了。

数据“断句”

在数据传输的过程中,我们需要处理“断句”,无论我们定义什么字符作为分隔符,它都有可能会在传输的数据中出现,为了区分“数据内的分隔符”和真正的分隔符,我们需要在发送数据阶段,加上分隔符之前,把数据内的分隔符做转义,收到数据之后再转义回来。

在实际应用中,更加实用的方法是我们在每句话前面加一个标识这句话长度的数字,收到书时,我们按照长度进行读取。

这种预置长度的方法很好的解决了“断句”的问题,并且实现的过程也比分隔符简单,性能也好。

单工和双工通信

所谓单工通信,是指在任何一个时刻,数据只能单向传输。

HTTP 1协议就是单工协议,客户端和服务端建立一个连接后,客户端发送一个请求,直到服务端返回响应或者请求超时,这段时间内,这个连接通道上是不能再发送其他请求的。这种单工通信的效率比较低,很多浏览器和App为了解决这个问题,只能同时在服务端和客户端之间创建很多连接。

所谓双工通信,是指我们可以同时进行数据的双向收发,互相不会受到任何影响。

TCP连接是一个全双工通道,为了提供吞吐量,应用层协议也必须支持双工通信。

在双工通信场景下,如何保证数据发送顺序呢?或者说如何保证响应和请求的对应关系呢?我们可以在发送请求的时候,给每个请求加一个序号,这个序号在本地会话内保证唯一,然后在响应中带上请求的序号,通过这种方式,我们可以建立响应和请求的对应关系。

解决断句问题,实现双工通信,配合专用的序列化方法,我们可以实现一套高性能的网络通信协议,实现高性能的进程间通信,很多消息队列、RPC框架都是用这种方式来实现它们自己的私有应用层传输协议。