rabbitMq 为什么不直接使用 TCP 发送消息,而是虚拟 channel?

2020-05-27 11:11:00 +08:00
 hercule

”对于 OS 来说,建立和关闭 TCP 连接是有代价的,频繁的建立关闭 TCP 连接对于系统的性能有很大的影响,而且 TCP 的连接数也有限制,这也限制了系统处理高并发的能力。但是,在 TCP 连接中建立 Channel 是没有上述代价的。“

上面这段话是很多技术文章写到的,也没具体的分析,我很纳闷,TCP 连接可以保持长连接,如果不显示关闭,也不会断开呀,我们也可以直接发送消息,只要不断开 TCP 就行,这样不会出现频繁的建立关闭 TCP 连接带来的开销啊。而且 channel 也是利用 TCP,简单来说,不管你多个 channel,始终是往一个 socket 上发送数据。除了 channel 有私密性以外。本质上为什么这样设置,如果只是系统消耗,好像说不过去。 如果是 http,我还能理解,一种 request/response 型的协议,为什么要做成 request/response 这种类型呢,因为 server 端要服务的 client 太多了,如果每一个连接都保持而不断开,那么服务器的 IO 很快就会被堵死了。但是 rabbitMQ 有点理解不了。 如果哪位大神知道为什么,麻烦指点一下。

1021 次点击
所在节点    程序员
2 条回复
RicardoY
2020-05-27 19:54:02 +08:00
channel 好像是 erlang 的原生概念
hercule
2020-05-27 19:56:38 +08:00
@RicardoY 谢谢

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/675894

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX