一幅图片引发的离婚大战
本文轉(zhuǎn)載自程序員技術(shù)
今天看到這兩幅圖片,不禁哈哈大笑。互聯(lián)網(wǎng)上很多段子或者笑話,其實(shí)最能引起笑果的往往來自于真實(shí)生活,而不是那些為了笑果而編造的段子。
微信真的會(huì)因?yàn)榫W(wǎng)絡(luò)不好而造成信息的前后顛倒嗎?
真的會(huì)。
為什么呢?
馬化騰說微信就是一個(gè)郵箱,只是這個(gè)郵箱比較快,讓你感受不到這是一個(gè)郵箱,而讓你有一種即時(shí)通信的錯(cuò)覺。
微信這個(gè)郵箱是這么來工作的:
Alice登錄微信服務(wù)器,認(rèn)證身份,上線狀態(tài)。這是一個(gè)基于TCP的長(zhǎng)連接,安全加密。所謂長(zhǎng)連接,就是Alice只要不是手機(jī)沒電或者關(guān)機(jī)狀態(tài),這個(gè)長(zhǎng)連接一直都是運(yùn)行且雙向可以通信的。這個(gè)負(fù)責(zé)登錄的服務(wù)器,簡(jiǎn)稱登錄服務(wù)器。
Alice給Bob發(fā)了一段文字,“Are you kidding me?”敲回車。這段文字是通過上文的長(zhǎng)連接發(fā)送的嗎?
不是的。而是通過一個(gè)短連接發(fā)送的,這個(gè)短連接是Alice點(diǎn)開Bob頭像才建立的,這是一個(gè) TCP + MMTLS(安全加密)+ http封裝的短連接。
然后這個(gè)消息就被短連接以http格式發(fā)出去了。這個(gè)消息是直接發(fā)給Bob的嗎?
不是的,而是發(fā)給Bob的郵箱。
Bob的郵箱是在Bob的手機(jī)里、還是微信存儲(chǔ)服務(wù)器里?
微信服務(wù)器。
這樣做有什么好處呢?
假如Bob在飛機(jī)上,手機(jī)關(guān)機(jī),Alice消息依然可以將消息發(fā)出。如果直接發(fā)給Bob手機(jī),手機(jī)都關(guān)機(jī)了,那就壓根無法建立連接,自然連消息都發(fā)不出。當(dāng)然好處還有許多,比如Alice與Bob的手機(jī)都位于NAT設(shè)備的后方,他們之間的直接通信不一定100%成功。
如果Bob是在線狀態(tài),登錄服務(wù)器會(huì)第一時(shí)間通過TCP長(zhǎng)連接,通知Bob微信郵箱里有信,至于這封信存在郵箱的什么地方,這是一個(gè)http格式的鏈接。Bob微信會(huì)與鏈接所對(duì)應(yīng)的存儲(chǔ)服務(wù)器建立短鏈接,將消息下載并顯示到本地窗口,然后關(guān)閉短連接。
如果Bob是離線狀態(tài),微信服務(wù)器其實(shí)也不急的,反正消息呆在存儲(chǔ)服務(wù)器,不會(huì)飛的。等Bob下飛機(jī)上線了第一時(shí)間通知Bob微信就好了。
以上就是微信的工作流程。接下來講為何微信會(huì)發(fā)生消息后發(fā)先至的情況?
微信每次敲完一段文字,點(diǎn)擊“發(fā)送“,這個(gè)消息就觸發(fā)了一次:
-
短連接的建立
-
消息的傳輸
-
短連接的斷開
這個(gè)是標(biāo)準(zhǔn)的三步曲。當(dāng)你再次發(fā)一段文字時(shí),又觸發(fā)了一次三步曲。兩次的三步曲是相互獨(dú)立的。
在網(wǎng)絡(luò)暢通時(shí),Alice第一個(gè)消息很快就發(fā)到Bob的郵箱,并被Bob微信呈現(xiàn)在窗口里。
Alice第二個(gè)消息發(fā)出的晚,自然到達(dá)得晚,這是非常好理解的。
但是當(dāng)網(wǎng)絡(luò)不好時(shí),第一個(gè)三步曲的消息報(bào)文不是那么幸運(yùn),丟了,然后Alice的手機(jī)一直在重傳這個(gè)消息。Alice又發(fā)送第二個(gè)消息,運(yùn)氣特別好,沒有丟,結(jié)果比第一個(gè)消息早到了幾秒。
既然微信講究及時(shí)通信,微信會(huì)第一時(shí)間通知Bob的微信,只是這個(gè)消息通知順序,先是第二個(gè)消息,然后才是第一個(gè)消息。這樣就造成了微信消息時(shí)序的顛倒。
最后,每一段消息內(nèi)部文字并沒有顛倒,對(duì)嗎?
這就是TCP的功勞,因?yàn)槎踢B接依然使用的是TCP做為傳輸協(xié)議,TCP最擅長(zhǎng)做的就是保證每一個(gè)字節(jié)按照先后順序到達(dá)。TCP是一個(gè)可靠協(xié)議,可以修復(fù)由于網(wǎng)絡(luò)暫時(shí)的中斷而造成的字節(jié)丟失。但是如果Alice向Bob郵箱上傳信的時(shí)候,網(wǎng)絡(luò)發(fā)生了長(zhǎng)時(shí)間的中斷,超出了TCP最大修復(fù)時(shí)間,這時(shí)微信會(huì)提示Alice,消息發(fā)送失敗!
總結(jié)
以上是生活随笔為你收集整理的一幅图片引发的离婚大战的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Day28-Linux入门01
- 下一篇: 《学习之道》读后感