溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Android端TCP長(zhǎng)連接性能優(yōu)化的示例分析

發(fā)布時(shí)間:2021-08-05 11:22:10 來源:億速云 閱讀:147 作者:小新 欄目:移動(dòng)開發(fā)

小編給大家分享一下Android端TCP長(zhǎng)連接性能優(yōu)化的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

推送長(zhǎng)連接

可以說大部分APP是離不開推送(push)這個(gè)功能的,不過平常我們都是接入第三方SDK(極光、個(gè)推等)居多,因?yàn)橐鲆粋€(gè)推送服務(wù),不光客戶端要編寫相應(yīng)的Socket通信代碼,服務(wù)器端更是麻煩,要處理大規(guī)模的長(zhǎng)連接服務(wù),消息還得及時(shí)送達(dá),一兩臺(tái)服務(wù)器可是吃不消。相對(duì)來說客戶端編寫Socket通信的代碼會(huì)簡(jiǎn)單一些,但是也是要處理一些平臺(tái)相關(guān)的問題,比如推送服務(wù)進(jìn)程如何?;?,APP進(jìn)程如何跟推送服務(wù)進(jìn)程通信,如何節(jié)省手機(jī)電量和手機(jī)弱網(wǎng)情況下如何提升通信質(zhì)量等一系列的問題。這些問題以后有時(shí)間分析,下面來看看TCP長(zhǎng)連接性能如何來優(yōu)化

影響TCP性能的點(diǎn)

TCP/IP體系太復(fù)雜了,想完全掌握確實(shí)很困難,我們只分析影響TCP性能的幾個(gè)因素,看看在Android客戶端可不可以進(jìn)行優(yōu)化

TCP連接的三次握手時(shí)延

我們知道要建立TCP連接,需要經(jīng)過三次握手,三次握手成功后連接建立成功

  • 客戶端請(qǐng)求新的連接,需要發(fā)送一個(gè)設(shè)置了SYN標(biāo)記的分組,向服務(wù)器說明這三個(gè)連接請(qǐng)求

  • 如何服務(wù)器接受了這個(gè)連接請(qǐng)求,會(huì)向客戶端回送一個(gè)設(shè)置了SYN和ACK的分組,向客戶端說明連接請(qǐng)求已經(jīng)被接受了

  • 客戶端收到這個(gè)表明連接請(qǐng)求被接受的分組后,要發(fā)送一條攜帶ACK標(biāo)記的確認(rèn)消息(可能會(huì)在這個(gè)消息中攜帶業(yè)務(wù)數(shù)據(jù))表明連接已經(jīng)建立成功了,可以開始發(fā)送數(shù)據(jù)了

那建立TCP連接的三次握手而產(chǎn)生的時(shí)延對(duì)我們會(huì)有影響嗎,大部分情況下是沒有的,只有當(dāng)HTTP請(qǐng)求傳輸?shù)臄?shù)據(jù)量比較小,然后呢這樣的HTTP請(qǐng)求又非常頻繁,這樣算下來,握手產(chǎn)生的時(shí)延占比就很高了,這種情況下就要通過重用已有的連接來減少連接的次數(shù)。而推送長(zhǎng)連接本身就是在保持連接的穩(wěn)定性,無需在這點(diǎn)上進(jìn)行優(yōu)化

延遲確認(rèn)

由于因特網(wǎng)本身無法保證可靠的分組傳輸,TCP就自己實(shí)現(xiàn)確認(rèn)機(jī)制來確保數(shù)據(jù)的可靠傳輸,成功接收TCP分組數(shù)據(jù)的接收者都需要向發(fā)送者回送一個(gè)小的確認(rèn)分組,發(fā)送者在一定的時(shí)間內(nèi)沒有收到這個(gè)確認(rèn)分組,就認(rèn)為之前發(fā)送的數(shù)據(jù)沒有成功,然后會(huì)重發(fā)數(shù)據(jù)

但是由于確認(rèn)分組非常的小,TCP為了有效的利用網(wǎng)絡(luò),會(huì)把確認(rèn)分組塞到同向傳輸數(shù)據(jù)中去,組合在一起發(fā)送傳輸,如果在一定的時(shí)間內(nèi)沒有同向傳輸數(shù)據(jù)咋辦,豈不是一直會(huì)重發(fā)?TCP肯定不會(huì)允許這種情況發(fā)送的,TCP針對(duì)這種情況實(shí)現(xiàn)了一種延遲確認(rèn)算法,在一定的窗口時(shí)間(一般是100~200毫秒),確認(rèn)分組還沒有被捎帶的話,那么確認(rèn)分組就會(huì)單獨(dú)發(fā)送

根據(jù)自己之前編寫TCP長(zhǎng)連接的經(jīng)驗(yàn),一般會(huì)在應(yīng)用層設(shè)計(jì)一個(gè)業(yè)務(wù)ACK包機(jī)制,當(dāng)收到一個(gè)業(yè)務(wù)數(shù)據(jù)時(shí),馬上會(huì)回送一個(gè)業(yè)務(wù)層的ACK包,這個(gè)業(yè)務(wù)層的ACK包就是同向傳輸數(shù)據(jù),確認(rèn)分組馬上會(huì)被捎帶,不會(huì)觸發(fā)延遲確認(rèn)算法,但是如果我們收到的消息頻率很高,那產(chǎn)生的ACK包就會(huì)非常的多,再假設(shè)業(yè)務(wù)層的ACK包并不需要那么的及時(shí),我們是否可以組合業(yè)務(wù)層ACK包再發(fā)送呢?

TCP慢啟動(dòng)

TCP連接的性能還受到擁塞控制機(jī)制的影響,當(dāng)TCP連接剛開始連接上時(shí),并不能一下子就發(fā)送很多的分組,可能是一開始只能發(fā)送一個(gè)分組,然后收到確認(rèn)分組后,就可以發(fā)送兩個(gè)分組,然后就是四個(gè)分組,以此類推。這個(gè)就是TCP慢啟動(dòng),發(fā)送數(shù)據(jù)的能力是慢慢提升的

由于我們編寫的是長(zhǎng)連接,這種機(jī)制對(duì)我們的影響并不大

Nagle算法

由于TCP并沒有規(guī)定每個(gè)分組最小值,所以我們可以每次都傳輸一個(gè)字節(jié)的數(shù)據(jù),但是TCP有固定的標(biāo)記和首部(至少40個(gè)字節(jié)),如果TCP發(fā)送大量的包含少量數(shù)據(jù)的分組時(shí),網(wǎng)絡(luò)的真實(shí)利用率就很低,網(wǎng)絡(luò)整體性能會(huì)嚴(yán)重的下降。

所以呢TCP利用了Nagle算法,在發(fā)送了一個(gè)分組前,將大量TCP數(shù)據(jù)綁定在一起,提高網(wǎng)絡(luò)的效率。Nagle算法鼓勵(lì)發(fā)送全尺寸的分組,而且只有當(dāng)所有的分組都被確認(rèn)后,才能發(fā)送非全尺寸的分組,不然的話就緩存起來,直到積累足夠發(fā)送一個(gè)全尺寸分組數(shù)據(jù)時(shí)才會(huì)將緩存的數(shù)據(jù)發(fā)送出去

那這個(gè)對(duì)我們編寫TCP長(zhǎng)連接時(shí)有什么影響呢,由于我們的心跳包和ACK包一般都很小,那么服務(wù)端就不能及時(shí)收到我們的心跳包和ACK包,會(huì)產(chǎn)生時(shí)延,可以通過下面的代碼來禁用Nagle算法

Socket.setTcpNoDelay(true);

TIME_WAIT累積與端口耗盡

這個(gè)跟服務(wù)端相關(guān),一般與客戶端沒什么關(guān)系,這里就不說了

以上是“Android端TCP長(zhǎng)連接性能優(yōu)化的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI