av激情亚洲男人的天堂国语,日韩欧美精品一中文字幕,无码av一区二区三区无码,国产又色又爽又刺激的a片,国产又色又爽又刺激的a片

MySQL服務器發(fā)現(xiàn)大量TIME_WAIT解決辦法

有同事就反映公司好幾個網(wǎng)站都打不開,登陸MySQL數(shù)據(jù)庫。服務器(Windows),發(fā)現(xiàn)很卡,于是重啟了下服務器,進入系統(tǒng)后,沒過一會問題依舊,查看了下系統(tǒng)進程,發(fā)現(xiàn)MySQL占用率達到99%,可以肯定的是MySQL連接出現(xiàn)問題:

石龍網(wǎng)站建設公司創(chuàng)新互聯(lián),石龍網(wǎng)站設計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為石龍上千多家提供企業(yè)網(wǎng)站建設服務。企業(yè)網(wǎng)站搭建\外貿(mào)營銷網(wǎng)站建設要多少錢,請找那個售后服務好的石龍做網(wǎng)站的公司定做!

 
 
 
  1. netstat -an 
  2. 192.168.12.13:3306 192.168.12.12:30443 TIME_WAIT
  3. 192.168.12.13:3306 192.168.12.12:30444 TIME_WAIT
  4. 192.168.12.13:3306 192.168.12.12:30445 TIME_WAIT
  5. 192.168.12.13:3306 192.168.12.12:30446 TIME_WAIT
  6. 192.168.12.13:3306 192.168.12.12:30447 TIME_WAIT
  7. 192.168.12.13:3306 192.168.12.12:30448 TIME_WAIT
  8. 192.168.12.13:3306 192.168.12.12:30449 TIME_WAIT
  9. 192.168.12.13:3306 192.168.12.12:30450 TIME_WAIT
  10. 192.168.12.13:3306 192.168.12.12:30451 TIME_WAIT
  11. 192.168.12.13:3306 192.168.12.12:30452 TIME_WAIT
  12. ... ...

根據(jù)TCP協(xié)議定義的3次握手斷開連接規(guī)定,發(fā)起socket主動關閉的一方 socket將進入TIME_WAIT狀態(tài),TIME_WAIT狀態(tài)將持續(xù)2個MSL(Max Segment Lifetime),在Windows下默認為4分鐘,即240秒,TIME_WAIT狀態(tài)下的socket不能被回收使用. 具體現(xiàn)象是對于一個處理大量短連接的服務器,如果是由服務器主動關閉客戶端的連接,將導致服務器端存在大量的處于TIME_WAIT狀態(tài)的socket, 甚至比處于Established狀態(tài)下的socket多的多,嚴重影響服務器的處理能力,甚至耗盡可用的socket,停止服務. TIME_WAIT是TCP協(xié)議用以保證被重新分配的socket不會受到之前殘留的延遲重發(fā)報文影響的機制,是必要的邏輯保證.

在HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters,添加名為TcpTimedWaitDelay的

DWORD鍵,設置為60,以縮短TIME_WAIT的等待時間

登陸到Web服務器(Linux):

 
 
 
  1.  netstat -ae |grep mysql
  2.     tcp        0      0 aaaa:53045              192.168.12.13:mysql          TIME_WAIT  root      0
  3. tcp        0      0 aaaa:53044              192.168.12.13:mysql          TIME_WAIT  root      0
  4. tcp        0      0 aaaa:53051              192.168.12.13:mysql          TIME_WAIT  root      0
  5. tcp        0      0 aaaa:53050              192.168.12.13:mysql          TIME_WAIT  root      0
  6. tcp        0      0 aaaa:53049              192.168.12.13:mysql          TIME_WAIT  root      0
  7. tcp        0      0 aaaa:53048              192.168.12.13:mysql          TIME_WAIT  root      0
  8. tcp        0      0 aaaa:53055              192.168.12.13:mysql          TIME_WAIT  root      0
  9. tcp        0      0 aaaa:53054              192.168.12.13:mysql          TIME_WAIT  root      0
  10. tcp        0      0 aaaa:53053              192.168.12.13:mysql          TIME_WAIT  root      0
  11. tcp        0      0 aaaa:53052              192.168.12.13:mysql          TIME_WAIT  root      0
  12. tcp        0      0 aaaa:53059              192.168.12.13:mysql          TIME_WAIT  root      0
  13. tcp        0      0 aaaa:53058              192.168.12.13:mysql          TIME_WAIT  root      0
  14. tcp        0      0 aaaa:53057              192.168.12.13:mysql          TIME_WAIT  root      0
  15. tcp        0      0 aaaa:53056              192.168.12.13:mysql          TIME_WAIT  root      0
  16. tcp        0      0 aaaa:53063              192.168.12.13:mysql          TIME_WAIT  root      0
  17. tcp        0      0 aaaa:53062              192.168.12.13:mysql          TIME_WAIT  root      0
  18. tcp        0      0 aaaa:53061              192.168.12.13:mysql          TIME_WAIT  root      0
  19. tcp        0      0 aaaa:53060              192.168.12.3:mysql          TIME_WAIT  root      0
  20. tcp        0      0 aaaa:53067              192.168.12.13:mysql          TIME_WAIT  root      0
  21. tcp        0      0 aaaa:53066              192.168.12.13:mysql          TIME_WAIT  root      0
  22. tcp        0      0 aaaa:53065              192.168.12.13:mysql          TIME_WAIT  root      0
  23. tcp        0      0 aaaa:53064              192.168.12.13:mysql          TIME_WAIT  root      0
  24. tcp        0      0 aaaa53071              192.168.12.13:mysql          TIME_WAIT  root      0
  25. tcp        0      0 aaaa:53070              192.168.12.13:mysql          TIME_WAIT  root      0
  26. tcp        0      0 aaaa:53069              192.168.12.13:mysql          TIME_WAIT  root      0

發(fā)現(xiàn)系統(tǒng)存在大量TIME_WAIT狀態(tài)的連接,通過調(diào)整內(nèi)核參數(shù)解決,

 
 
 
  1. vi /etc/sysctl.conf

編輯文件,加入以下內(nèi)容:

 
 
 
  1. net.ipv4.tcp_syncookies = 1
  2. net.ipv4.tcp_tw_reuse = 1
  3. net.ipv4.tcp_tw_recycle = 1
  4. net.ipv4.tcp_fin_timeout = 30

然后執(zhí)行 /sbin/sysctl -p 讓參數(shù)生效。

net.ipv4.tcp_syncookies = 1 表示開啟SYN Cookies。當出現(xiàn)SYN等待隊列溢出時,啟用cookies來處理,可防范少量SYN攻擊,默認為0,表示關閉;

net.ipv4.tcp_tw_reuse = 1 表示開啟重用。允許將TIME-WAIT sockets重新用于新的TCP連接,默認為0,表示關閉;

net.ipv4.tcp_tw_recycle = 1 表示開啟TCP連接中TIME-WAIT sockets的快速回收,默認為0,表示關閉。

net.ipv4.tcp_fin_timeout 修改系統(tǒng)默認的 TIMEOUT 時間

修改之后,再用

 
 
 
  1. netstat -ae|grep mysql
  2. tcp        0      0 aaaa:50408              192.168.12.13:mysql          ESTABLISHED nobody    3224651
  3. tcp        0      0 aaaa:50417              192.168.12.13:mysql          ESTABLISHED nobody    3224673
  4. tcp        0      0 aaaa:50419              192.168.12.13:mysql          ESTABLISHED nobody    3224675

發(fā)現(xiàn)大量的TIME_WAIT 已不存在,mysql進程的占用率很快就降下來的,各網(wǎng)站訪問正常!!

以上只是暫時的解決方法,最后仔細巡查發(fā)現(xiàn)是前天新上線的一個系統(tǒng),程序代碼中沒有使用mysql.colse(),才導致大量的mysql TIME_WAIT。


本文標題:MySQL服務器發(fā)現(xiàn)大量TIME_WAIT解決辦法
文章地址:http://uogjgqi.cn/article/dhgcgid.html
掃二維碼與項目經(jīng)理溝通

我們在微信上24小時期待你的聲音

解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯(lián)網(wǎng)交流