一次微信聊天引发的离婚大战!

网络 通信技术 开发工具
今天看到这两幅图片,不禁哈哈大笑。互联网上很多段子或者笑话,其实最能引起笑果的往往来自于真实生活,而不是那些为了笑果而编造的段子。

 今天看到这两幅图片,不禁哈哈大笑。互联网上很多段子或者笑话,其实最能引起笑果的往往来自于真实生活,而不是那些为了笑果而编造的段子。

[[436038]]

图片来自 包图网

微信真的会因为网络不好而造成信息的前后颠倒吗?真的会。

为什么呢?马化腾说微信就是一个邮箱,只是这个邮箱比较快,让你感受不到这是一个邮箱,而让你有一种即时通信的错觉。

微信这个邮箱是这么来工作的:Alice 登录微信服务器,认证身份,上线状态。这是一个基于 TCP 的长连接,安全加密。

所谓长连接,就是 Alice 只要不是手机没电或者关机状态,这个长连接一直都是运行且双向可以通信的。这个负责登录的服务器,简称登录服务器。

Alice 给 Bob 发了一段文字,“Are you kidding me?”敲回车。这段文字是通过上文的长连接发送的吗?

不是的。而是通过一个短连接发送的,这个短连接是 Alice 点开 Bob 头像才建立的,这是一个 TCP + MMTLS(安全加密)+ HTTP 封装的短连接。

然后这个消息就被短连接以 HTTP 格式发出去了。这个消息是直接发给 Bob 的吗?

不是的,而是发给 Bob 的邮箱。Bob 的邮箱是在 Bob 的手机里、还是微信存储服务器里?

微信服务器。这样做有什么好处呢?

假如 Bob 在飞机上,手机关机,Alice 消息依然可以将消息发出。如果直接发给 Bob 手机,手机都关机了,那就压根无法建立连接,自然连消息都发不出。

当然好处还有许多,比如 Alice 与 Bob 的手机都位于 NAT 设备的后方,他们之间的直接通信不一定 100% 成功。

如果 Bob 是在线状态,登录服务器会第一时间通过 TCP 长连接,通知 Bob 微信邮箱里有信,至于这封信存在邮箱的什么地方,这是一个 HTTP 格式的链接。

Bob 微信会与链接所对应的存储服务器建立短链接,将消息下载并显示到本地窗口,然后关闭短连接。

如果 Bob 是离线状态,微信服务器其实也不急的,反正消息呆在存储服务器,不会飞的。等 Bob 下飞机上线了第一时间通知 Bob 微信就好了。

以上就是微信的工作流程。接下来讲为何微信会发生消息后发先至的情况?

微信每次敲完一段文字,点击“发送“,这个消息就触发了一次:

  • 短连接的建立
  • 消息的传输
  • 短连接的断开

这个是标准的三步曲。当你再次发一段文字时,又触发了一次三步曲。两次的三步曲是相互独立的。

在网络畅通时,Alice 第一个消息很快就发到 Bob 的邮箱,并被 Bob 微信呈现在窗口里。Alice 第二个消息发出的晚,自然到达得晚,这是非常好理解的。

但是当网络不好时,第一个三步曲的消息报文不是那么幸运,丢了,然后 Alice 的手机一直在重传这个消息。Alice 又发送第二个消息,运气特别好,没有丢,结果比第一个消息早到了几秒。

既然微信讲究及时通信,微信会第一时间通知 Bob 的微信,只是这个消息通知顺序,先是第二个消息,然后才是第一个消息。这样就造成了微信消息时序的颠倒。

最后,每一段消息内部文字并没有颠倒,对吗?

这就是 TCP 的功劳,因为短连接依然使用的是 TCP 做为传输协议,TCP 最擅长做的就是保证每一个字节按照先后顺序到达。

TCP 是一个可靠协议,可以修复由于网络暂时的中断而造成的字节丢失。但是如果 Alice 向 Bob 邮箱上传信的时候,网络发生了长时间的中断,超出了 TCP 最大修复时间,这时微信会提示 Alice,消息发送失败!

作者:车小胖谈网络

编辑:陶家龙

来源:转载自公众号车小胖谈网络(ID:chexiaopangnetwork)

 

责任编辑:武晓燕 来源: 车小胖谈网络
相关推荐

2021-11-01 17:29:02

Windows系统Fork

2017-08-24 17:37:18

DNS缓存分析

2024-05-13 08:37:17

炫技H5UI

2018-12-27 09:09:35

2023-07-13 09:12:37

CNCF项目云原生

2019-11-04 10:37:53

MongoDB宕机日志

2018-01-04 13:53:43

技术命令windows

2021-03-17 00:17:16

命令应急响应

2022-11-29 21:26:26

跨域配置

2020-02-04 14:27:09

架构技术栈微信半月刊

2018-07-16 22:29:29

代码迭代质量

2020-01-06 09:43:14

赔偿TSB迁移

2019-01-16 09:20:42

架构设计JVM FullGC宕机事故

2021-09-08 14:50:38

微信聊天记录移动应用

2022-06-14 08:00:28

切换包管理器版本

2022-12-17 19:49:37

GCJVM故障

2015-07-17 10:05:03

面试思考

2017-09-01 09:17:51

DNS缓存惨案

2011-06-28 10:41:50

DBA

2016-11-28 15:52:09

微信小程序开发
点赞
收藏

51CTO技术栈公众号