Linux TCP併發請求溺出 調優

TCP併發請求溺出網絡

調優:系統開啓某個監聽端口後,當多個TCP請求鏈接監聽端後,會把多個請求交給backlog的默認監聽隊列由socket server一併處理,backlog有本身的隊列長度默認128,當機器處理能力較慢且併發請求值較高時就要考慮對backlog隊列進行調優。數據結構

注:backlog就是socket的監聽隊列,當一個請求還沒有被處理或創建時,他會進入backlog。併發

注:socket server能夠一次性處理backlog中的全部請求,處理後的請求再也不位於監聽隊列中。當server處理請求較慢,以致於監聽隊列被填滿後,新來的請求會被拒絕。socket


TCP內核參數修改 調優tcp

修改文件:/etc/sysctl.conf函數

生效命令:sysctl -p /etc/sysctl.conf性能

# 用於設置內核沒法及時處理網絡接口收到的數據包時容許發送到隊列的最大數據包數目,默認爲128。
net.core.netdev_max_backlog = 32768

# 用來限制監聽(LISTEN)隊列最大數據包的數量,超過這個數量就會致使連接超時或者觸發重傳機制
net.core.somaxconn= 32768

# 表示SYN隊列的長度,默認值爲1024,此處加大隊列長度爲65535,能夠容納更多等待鏈接的網絡鏈接數。
net.ipv4.tcp_max_syn_backlog=65535

注:根據機器性能調試併發數調優。大數據


somaxconn與tcp_max_syn_backlog區別spa

socket接收的全部鏈接都是存放在隊列類型的數據結構中,關鍵問題是這種隊列有兩個,並且其長度都是能夠設置的。.net

/proc/sys/net/ipv4/tcp_max_syn_backlog /proc/sys/net/core/somaxconn

注:tcp_max_syn_backlog是指定所能接受SYN同步包的最大客戶端數量,即半鏈接上限。
注:somaxconn是指服務端所能accept即處理數據的最大客戶端數量,即完成鏈接上限。

  • 一、到大廳;tcp_max_syn_backlog用於指定酒席現場面積容許容納多少人進來;
  • 二、找到座位(吃東西,好比糖果、飯菜、酒等)。somaxconn用於指定有多少個座位。
tcp_max_syn_backlog>=somaxconn

:somaxconn是內核裏的參數,listen函數有個參數backlog,若是在listen方法裏面指定該參數大於somaxconn的值,從新編譯並啓動程序,服務端所能接收的完整的鏈接數上限是backlog呢仍是somaxconn?

答案:listen方法指定的backlog是在用戶態指定的,內核態的參數優先級高於用戶態的參數,因此即便在listen方法裏面指定backlog是一個大於somaxconn的值,socket在內核態運行時還會檢查一次somaxconn,若是鏈接數超過somaxconn就會等待。就至關於主人指定了能有多少座位沒用,客人到了現場,準備入座時,還要看酒店的客戶經理判斷能有多少個座位。

相關文章
相關標籤/搜索