如何提高Linux系統應對短連線的負載能力
在存在大量短連線的情況下,Linux的TCP棧一般都會生成大量的 TIME_WAIT 狀態的socket。
你可以用下面的命令看到:
netstat -ant| grep -i time_wait
有時候,這個數目是驚人的:
netstat -ant|grep -i time_wait |wc -l
可能會超過三四萬。這個時候,我們需要修改 linux kernel 的 tcp time wait的時間,縮短之,有個 sysctl 引數貌似可以使用,它是 /proc/sys/net/ipv4/tcp_fin_timeout,預設值是 60,也就是60秒,很多網上的資料都說將這個數值設定低一些就可以減少netstat 裡面的TIME_WAIT狀態,但是這個說法是錯誤的。經過認真閱讀Linux的核心原始碼,我們發現這個數值其實是輸出用的,修改之後並沒有真正的讀回核心中進行使用,而核心中真正管用的是一個宏定義,在 $KERNEL/include/net/tcp.h裡面,有下面的行:
#define TCP_TIMEWAIT_LEN (60*HZ)
而這個宏是真正控制 TCP TIME_WAIT 狀態的超時時間的。如果我們希望減少 TIME_WAIT 狀態的數目(從而節省一點點核心操作時間),那麼可以把這個數值設定低一些,根據我們的測試,設定為 10 秒比較合適,也就是把上面的修改為:
#define TCP_TIMEWAIT_LEN (10*HZ)
然後重新編譯核心,重啟系統即可發現短連線造成的TIME_WAIT狀態大大減少:
netstat -ant | grep -i time_wait |wc -l
一般情況都可以至少減少2/3,也能相應提高系統應對短連線的速度。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69942496/viewspace-2652130/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Linux 如何檢視系統負載Linux負載
- (1)Linux系統中到底應該怎麼理解系統的平均負載Linux負載
- 如何解決linux系統平均負載高(load average)Linux負載
- (譯)理解Linux系統的CPU負載均值Linux負載
- Linux作業系統中如何連線Microsoft OneDriveLinux作業系統ROS
- vmstat檢視分析Linux系統負載效能Linux負載
- 阿里雲輕量應用伺服器如何遠端連線Linux系統阿里伺服器Linux
- Linux 中模擬多種系統負載的方法Linux負載
- VNC,Linux系統下如何安裝和連線VNC!VNCLinux
- NoSQL中負載均衡系統如何解決熱點問題,提高可用性?SQL負載
- Linux基礎命令---tload顯示系統負載Linux負載
- 在Deepin Linux作業系統中如何連線Microsoft OneDriveLinux作業系統ROS
- linux系統影響tcp連線數的因素LinuxTCP
- http的長連線和短連線HTTP
- 長連線和短連線的使用
- SAP ECC系統連線SAP PI系統的系統連線配置
- Linux 中的負載高低和 CPU 開銷並不完全對應Linux負載
- 長連線和短連線
- 聊聊系統平均負載負載
- 輪詢、長輪詢、短連線、長連線區別對比
- Linux系統的命令應該如何記?Linux
- phpStorm 如何用 FTP,SSH 連線到虛擬機器 Linux 系統?PHPORMFTP虛擬機Linux
- w10系統怎麼連線wifi_win10系統如何連線wifiWiFiWin10
- 9 個提高系統執行速度的輕量級 Linux 應用Linux
- 為什麼要遠端連線Linux系統?linux作業系統入門Linux作業系統
- linux系統檢視網路連線情況Linux
- Linux平均負載Linux負載
- 在Linux中,如何實現負載均衡?Linux負載
- 短連結系統的設計與實現
- WindTerm的安裝及遠端連線Linux系統步驟Linux
- 如何針對服務是否有重新連線資料庫的能力進行測試資料庫
- win10系統遠端桌面連線時如何顯示對方的工作列Win10
- Windows10系統下edge連線不了應用商店如何解決Windows
- Linux 系統如何通過 netstat 命令檢視連線數判斷攻擊Linux
- Linux 系統如何透過 netstat 命令檢視連線數判斷攻擊Linux
- 有限成本下,如何應對工作負載規模化帶來的安全挑戰負載
- Linux LVS 負載均衡Linux負載
- 如何對Wormhole進行連線Worm