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

推荐订阅源

SecWiki News
SecWiki News
H
Help Net Security
罗磊的独立博客
Stack Overflow Blog
Stack Overflow Blog
M
MIT News - Artificial intelligence
Jina AI
Jina AI
L
LangChain Blog
K
Kaspersky official blog
I
Intezer
Martin Fowler
Martin Fowler
爱范儿
爱范儿
AWS News Blog
AWS News Blog
The Hacker News
The Hacker News
Recorded Future
Recorded Future
人人都是产品经理
人人都是产品经理
H
Hackread – Cybersecurity News, Data Breaches, AI and More
C
CXSECURITY Database RSS Feed - CXSecurity.com
Spread Privacy
Spread Privacy
Simon Willison's Weblog
Simon Willison's Weblog
U
Unit 42
N
News and Events Feed by Topic
A
Arctic Wolf
G
GRAHAM CLULEY
Microsoft Azure Blog
Microsoft Azure Blog
博客园 - 聂微东
F
Fortinet All Blogs
C
Cisco Blogs
美团技术团队
Vercel News
Vercel News
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
H
Hacker News: Front Page
T
Tailwind CSS Blog
I
InfoQ
宝玉的分享
宝玉的分享
Google DeepMind News
Google DeepMind News
博客园 - 司徒正美
P
Palo Alto Networks Blog
A
About on SuperTechFans
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
云风的 BLOG
云风的 BLOG
TaoSecurity Blog
TaoSecurity Blog
Google Online Security Blog
Google Online Security Blog
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
P
Privacy & Cybersecurity Law Blog
H
Heimdal Security Blog
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Hacker News: Ask HN
Hacker News: Ask HN
O
OpenAI News
博客园 - Franky
Scott Helme
Scott Helme

博客园 - 李潘

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

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

数据“断句”

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

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

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

单工和双工通信

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

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

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

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

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

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