[20200312]不要設定net.ipv4.tcp_tw_recycle=1.txt
[20200312]不要設定net.ipv4.tcp_tw_recycle=1.txt
--//昨天認真看了2篇blog:
https://vincent.bernat.ch/en/blog/2014-tcp-time-wait-state-linux
--//中文翻譯:
--//裡面提到不要設定net.ipv4.tcp_tw_recycle=1。TIME_WAIT狀態問題不是太嚴重,可以完全不理會它。
--//我仔細閱讀,說真的許多一些細節還不是很理解。我開始接觸主要是不理解生產系統rac環境為什麼這麼多state=TIME_WAIT.
--//現在看來自己純粹是畫蛇添足,浪費時間,不過自己感覺還是學到許多東西.
--//現在我大概知道原因,做一些總結:
1.實際上對於正常資料庫應用,正常退出應用程式,實際上state=TIME_WAIT發生在客戶端,這也是我開始的困惑。服務端不應該這個多
state=TIME_WAIT。我的問題實際上由此展開^_^.
https://vincent.bernat.ch/en/blog/2014-tcp-time-wait-state-linux
TCP state diagram
Only the end closing the connection first will reach the TIME-WAIT state. The other end will follow a path which usually
permits to quickly get rid of the connection.
--//只有先關閉連線的結束才會達到TIME-WAIT狀態.. 另一端將沿著通常允許快速擺脫連線。
2.我們使用dblink短連線很多,這時服務端實際上變成客戶端,導致state=TIME_WAIT多。
3.exadata 出廠設定 net.ipv4.tcp_timestamps = 0,即使我設定net.ipv4.tcp_tw_recycle=1也無效,毫無作用,這也是我在測試中遇
到的第二個困惑。我想oracle這樣做可能有它的道理, 不會使用特殊的方式規避其它dba設定net.ipv4.tcp_tw_recycle=1的問題。
--//exadate 的 /etc/sysctl.conf設定,不知道前面# 12650500 ,oracle內部表示什麼?
# 12650500
net.ipv4.tcp_timestamps = 0
--//再次提醒建議不要設定net.ipv4.tcp_tw_recycle=1 解決大量state=TIME_WAIT問題。
4.還有1個原因導致服務端state=TIME_WAIT增多,就是客戶端連線RAC資料庫使用scan ip,會跳轉到vip ip,這樣一旦大量使用者以這種方式
登入,就是在服務端產生大量的state=TIME_WAIT連線。
5.還有前臺客戶端基本都是XP機器。我的測試MS關於tcp_timestamps預設設定是關閉的,至少在windows 7,windows 2003伺服器版下,XP
我不知道。
這樣即使服務端設定 net.ipv4.tcp_timestamps = 1 和 net.ipv4.tcp_tw_recycle=1 依舊在服務端生產大量的state=TIME_WAIT.
不過linux機器預設設定都是net.ipv4.tcp_timestamps = 1。
--//再次提醒建議不要設定net.ipv4.tcp_tw_recycle=1 解決大量state=TIME_WAIT問題。
--//注:我在這裡測試時又犯了一個錯誤,以為跨網段的機器不能快速回收TIME_WAIT,實際上是我的測試機器windows7的
--//tcp_timestamps預設設定是關閉的.
6.有一個可行的方法減少大量state=TIME_WAIT連線,就是在一些中介軟體伺服器可以不要使用scan ip連線資料庫,採用老的vip ip就可以
減少這樣的情況。改動涉及中介軟體伺服器,影響不大,這是比較可行成本最低的改進方法,僅僅對rac環境有效.
--//話又反活來講,如果不是rac環境,可能就看不到大量的state=TIME_WAIT狀態.
7.如果網路連結透過公網或者NAT轉換,肯定不能設定net.ipv4.tcp_tw_recycle=1. 由於我們一些應用透過公網,當我設定
net.ipv4.tcp_tw_recycle=1
net.ipv4.tcp_timestamps=1
--//確實有少量的客戶端(實際上也就2臺)無法連線伺服器的情況,甚至內網的機器也出現一臺,我不知道為什麼。最終還原原來設定
net.ipv4.tcp_tw_recycle=0
net.ipv4.tcp_timestamps=0
8.記憶體 CPU 資源消耗很少。參考連結的測試:https://vincent.bernat.ch/en/blog/2014-tcp-time-wait-state-linux
9.state=TIME_WAIT對應用影響很小,4元素組成一個連線,oracle 建議核心引數設定net.ipv4.ip_local_port_range = 1024 65000
支援埠數量達到64000,這樣如果不達到每秒60000/60 = 1000 個/連線,基本影響可以忽略。
我感覺不能達到這個數量,至少我自己沒見過。我們資料庫高峰也就是200個/每秒連線。
10.TIME_WAIT狀態的消失時間在linux下寫死的,在net/tcp.h標頭檔案裡面的,許多連結提示修改net.ipv4.tcp_fin_timeout是錯誤的:
--//除非修改標頭檔案內容,重新編譯核心!!
#define TCP_TIMEWAIT_LEN (60*HZ) /* how long to wait to destroy TIME-WAIT
* state, about 60 seconds */
#define TCP_FIN_TIMEOUT TCP_TIMEWAIT_LEN
/* BSD style FIN_WAIT2 deadlock breaker.
* It used to be 3min, new value is 60sec,
* to combine FIN-WAIT-2 timeout with
* TIME-WAIT timer.
*/
11.windows下可以修改TIME_WAIT狀態的消失時間:
--//在HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters上新增一個DWORD型別的值TcpTimedWaitDelay,值
--//就是秒數,最小30秒,不能低於該值.注要重啟機器才能生效:
--//timewait.reg
REGEDIT4
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\Tcpip\Parameters]
"TcpTimedWaitDelay"=dword:0000001e
12.windows下設定tcp_timestamps:
--//按照(v=technet.10)?redirectedfrom=MSDN
Tcp1323Opts
--//注:1323 應該是關聯RFC 1323文件.
HKLM\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters
Data type Range Default value
------------------------------------------
REG_DWORD 0 | 1 | 2 | 3 3
Value Meaning
0 (00) Timestamps and window scaling are disabled.
1 (01) Window scaling is enabled.
2 (10) Timestamps are enabled.
3 (11) Timestamps and window scaling are enabled.
--//按照介紹MS預設應該是開啟tcp_timestamps的。不過我發現在windows 7,windows 2003下不是這樣。修改為2或者3.我僅僅測試修改3
--//的情況.
REGEDIT4
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\Tcpip\Parameters]
"Tcp1323Opts"=hex:03
13.最後簡單講一下測試方法,使用tnsping server_ip count > /dev/null,這樣比較簡單快捷,這時state=TIME_WAIT出現在服務端,使用
netstat -ntop 或者ss -nto 觀察.
# seq 10000 | xargs -IQ bash -c "ss -tano state time-wait | ts.awk ; sleep 1"
or
# seq 10000 | xargs -IQ bash -c "netstat -nto | grep TIME-WAIT | ts.awk ; sleep 1"
$ cat $(which ts.awk)
# /bin/bash
gawk '{ print strftime("[%Y-%m-%d %H:%M:%S]"), $0 }'
在服務端net.ipv4.tcp_tw_recycle=1,net.ipv4.tcp_timestamps=1,客戶端net.ipv4.tcp_timestamps=1的情況下服務端出現TIME_WAIT很快消失.
在服務端net.ipv4.tcp_tw_recycle=1,net.ipv4.tcp_timestamps=1,客戶端net.ipv4.tcp_timestamps=0的情況下服務端出現TIME_WAIT等60秒消失.
在服務端net.ipv4.tcp_tw_recycle=1,net.ipv4.tcp_timestamps=0, 服務端出現TIME_WAIT等60秒消失.
在服務端net.ipv4.tcp_tw_recycle=0,net.ipv4.tcp_timestamps=N(N=1,0) 服務端出現TIME_WAIT等60秒消失.
--//大家可以自行測試.測試結果就不貼上來了,有點繁瑣.
--//從這裡也看出如果大量的客戶端是windows,沒有開啟tcp_timestamp,在服務端設定
--//net.ipv4.tcp_tw_recycle=1,net.ipv4.tcp_timestamps=1也一樣毫無用處.
14.演示一個服務端產生大量TIME_WAIT的例子:
--//還是另外寫一篇,不然寫的又太長了.
--//最後再次提醒建議不要設定net.ipv4.tcp_tw_recycle=1來解決大量state=TIME_WAIT問題,重要的問題說三遍,國內大量的連結這樣
--//做可能會導致一些網路故障非常難查,除非應用都是非常純的內網環境裡面。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/267265/viewspace-2679948/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 程式設計師一定不要固步自封程式設計師
- 不要用Appearance proxy設定UIView的tintColorAPPUIView
- 不要再強迫我設定複雜密碼密碼
- 不要把你的input元素設定為“action”或“submit”MIT
- 請不要設定目標!而是專注於系統 - jamesclear
- 不要在 XML 設定,解決 NestedScrollView 巢狀 RecyclerView 滑動卡頓XMLView巢狀
- 不要現場程式設計程式設計
- 不要if else的程式設計程式設計
- 不要逼我結對程式設計程式設計
- 網路優化之net.ipv4.tcp_tw_recycle引數優化TCP
- [20170425]變態的windows批處理1.txtWindows
- 不要問程式設計師什麼是“物件”,也不要給他介紹“物件”程式設計師物件
- 程式設計師們,千萬不要接私活程式設計師
- 不要陷入極限程式設計的陷阱程式設計
- 由ora-30036引出的問題,給大表新增列的時候,不要設定預設值
- net.ipv4.tcp_tw_recycle = 1會導致什麼問題產生TCP
- Laravel setting 設定 / 系統設定 / 網站設定Laravel網站
- 程式設計師到底要不要接外包?程式設計師
- 程式設計師千萬不要學演算法!程式設計師演算法
- 請不要說自己是Java程式設計師Java程式設計師
- 請不要說自己是 Java 程式設計師Java程式設計師
- 不要將Actors用於併發程式設計程式設計
- 程式設計師,千萬不要重寫程式碼程式設計師
- 不要做一個浮躁的程式設計師程式設計師
- 沒搞懂背後原因,不要盲目程式設計程式設計
- Nacos 爆重大 Bug!!不要升級,不要升級,不要升級
- [20170309]關於線上日誌與歸檔1.txt
- 2021年Z世代報告:理解我,不要定義我
- 不要輕易定義指向std::vector中的元素的指標指標
- 千萬不要寫程式碼不要讀博
- 程式設計師,請你不要在坑程式設計師了?程式設計師
- 你不知道的React迴圈渲染時為什麼儘量不要把索引設定為key值?React索引
- 程式設計師為什麼千萬不要瞎努力?程式設計師
- 程式設計師不要成為工具的奴隸程式設計師
- 不要用return false阻止event的預設行為False
- UI設計師要不要真的懂技術?UI
- 程式設計師,你的職業不要固步自封程式設計師
- 為什麼說你不要獨自程式設計程式設計