提高Linux系統(tǒng)性能加速網(wǎng)絡(luò)應(yīng)用程序 |
發(fā)布時間: 2012/8/26 17:44:11 |
在開發(fā) socket 應(yīng)用程序時, 首要任務(wù)通常是確?煽啃圆M足一些特定的需求。利用本文中給出的 4 個提示,您就可以從頭開始為實現(xiàn)最佳性能來設(shè)計并開發(fā) socket 程序。本文內(nèi)容包括對于 Sockets API 的使用、兩個可以提高性能的 socket 選項以及 GNU/Linux 優(yōu)化。
為了能夠開發(fā)性能卓越的應(yīng)用程序,請遵循以下技巧: 最小化報文傳輸?shù)难訒r。 最小化系統(tǒng)調(diào)用的負載。 為 Bandwidth Delay Product 調(diào)節(jié) TCP 窗口。 動態(tài)優(yōu)化 GNU/Linux TCP/IP 棧。 技巧 1. 最小化報文傳輸?shù)难訒r 在通過 TCP socket 進行通信時,數(shù)據(jù)都拆分成了數(shù)據(jù)塊,這樣它們就可以封裝到給定連接的 TCP payload(指 TCP 數(shù)據(jù)包中的有效負荷)中了。TCP payload 的大小取決于幾個因素(例如最大報文長度和路徑),但是這些因素在連接發(fā)起時都是已知的。為了達到最好的性能,我們的目標(biāo)是使用盡可能多的可用數(shù)據(jù)來填充 每個報文。當(dāng)沒有足夠的數(shù)據(jù)來填充 payload 時(也稱為最大報文段長度(maximum segment size) 或 MSS),TCP 就會采用 Nagle 算法自動將一些小的緩沖區(qū)連接到一個報文段中。這樣可以通過最小化所發(fā)送的報文的數(shù)量來提高應(yīng)用程序的效率,并減輕整體的網(wǎng)絡(luò)擁塞問題。 盡管 John Nagle 的算法可以通過將這些數(shù)據(jù)連接成更大的報文來最小化所發(fā)送的報文的數(shù)量,但是有時您可能希望只發(fā)送一些較小的報文。一個簡單的例子是 telnet 程序,它讓用戶可以與遠程系統(tǒng)進行交互,這通常都是通過一個 shell 來進行的。如果用戶被要求用發(fā)送報文之前輸入的字符來填充某個報文段,那么這種方法就絕對不能滿足我們的需要。 另外一個例子是 HTTP 協(xié)議。通常,客戶機瀏覽器會產(chǎn)生一個小請求(一條 HTTP 請求消息),然后 Web 服務(wù)器就會返回一個更大的響應(yīng)(Web 頁面)。 解決方案 您應(yīng)該考慮的第一件事情是 Nagle 算法滿足一種需求。由于這種算法對數(shù)據(jù)進行合并,試圖構(gòu)成一個完整的 TCP 報文段,因此它會引入一些延時。但是這種算法可以最小化在線路上發(fā)送的報文的數(shù)量,因此可以最小化網(wǎng)絡(luò)擁塞的問題。 但是在需要最小化傳輸延時的情況中,Sockets API 可以提供一種解決方案。要禁用 Nagle 算法,您可以設(shè)置 TCP_NODELAY socket 選項,如清單 1 所示。 int sock, flag, ret; /* Create new stream socket */ sock = socket( AF_INET, SOCK_STREAM, 0 ); /* Disable the Nagle (TCP No Delay) algorithm */ flag = 1; ret = setsockopt( sock, IPPROTO_TCP, TCP_NODELAY, (char *)&flag, sizeof(flag) ); if (ret == -1) { printf("Couldn't setsockopt(TCP_NODELAY)\n"); exit(-1); } 清單 1. 為 TCP socket 禁用 Nagle 算法 提示:使用 Samba 的實驗表明,在從 Microsoft® Windows® 服務(wù)器上的 Samba 驅(qū)動器上讀取數(shù)據(jù)時,禁用 Nagle 算法幾乎可以加倍提高讀性能。 本文出自:億恩科技【1tcdy.com】 服務(wù)器租用/服務(wù)器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM] |