91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

學(xué)習(xí)Linux命令的正確姿勢

倩倩 ? 來源:開源Linux ? 作者:開源Linux ? 2022-08-31 10:27 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群


	

學(xué)習(xí)Linux命令的正確姿勢


	

	

	

問題描述

模擬高并發(fā)的場景,會出現(xiàn)批量的 TIME_WAIT 的 TCP 連接:
cfb29db8-28d3-11ed-ba43-dac502259ad0.png短時間后,所有的 TIME_WAIT 全都消失,被回收,端口包括服務(wù),均正常。即,在高并發(fā)的場景下,TIME_WAIT 連接存在,屬于正?,F(xiàn)象。線上場景中,持續(xù)的高并發(fā)場景:
  • 一部分 TIME_WAIT 連接被回收,但新的 TIME_WAIT 連接產(chǎn)生;

  • 一些極端情況下,會出現(xiàn)大量的 TIME_WAIT 連接。

Think:上述大量的 TIME_WAIT 狀態(tài) TCP 連接,有什么業(yè)務(wù)上的影響嗎?
Nginx 作為反向代理時,大量的短鏈接,可能導(dǎo)致 Nginx 上的 TCP 連接處于 time_wait 狀態(tài):
  • 每一個 time_wait 狀態(tài),都會占用一個「本地端口」,上限為 65535(16 bit,2 Byte);

  • 當(dāng)大量的連接處于 time_wait 時,新建立 TCP 連接會出錯,address already in use : connect 異常

統(tǒng)計(jì) TCP 連接的狀態(tài):

	

		// 統(tǒng)計(jì):各種連接的數(shù)量 $ netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}' ESTABLISHED 1154 TIME_WAIT 1645Tips:TCP 本地端口數(shù)量,上限為 65535(6.5w),這是因?yàn)?TCP 頭部使用 16 bit,存儲「端口號」,因此約束上限為 65535。

問題分析

大量的 TIME_WAIT 狀態(tài) TCP 連接存在,其本質(zhì)原因是什么?
  1. 大量的短連接存在

  2. 特別是 HTTP 請求中,如果 connection 頭部取值被設(shè)置為 close 時,基本都由「服務(wù)端」發(fā)起主動關(guān)閉連接

  3. 而,TCP 四次揮手關(guān)閉連接機(jī)制中,為了保證 ACK 重發(fā)和丟棄延遲數(shù)據(jù),設(shè)置 time_wait 為 2 倍的 MSL(報文最大存活時間)

TIME_WAIT 狀態(tài):
  1. TCP 連接中,主動關(guān)閉連接的一方出現(xiàn)的狀態(tài);(收到 FIN 命令,進(jìn)入 TIME_WAIT 狀態(tài),并返回 ACK 命令)

  2. 保持 2 個 MSL 時間,即,4 分鐘;(MSL 為 2 分鐘)

解決辦法

解決上述 time_wait 狀態(tài)大量存在,導(dǎo)致新連接創(chuàng)建失敗的問題,一般解決辦法:
  1. 客戶端,HTTP 請求的頭部,connection 設(shè)置為 keep-alive,保持存活一段時間:現(xiàn)在的瀏覽器,一般都這么進(jìn)行了

  2. 服務(wù)器端 允許 time_wait 狀態(tài)的 socket 被重用 縮減 time_wait 時間,設(shè)置為 1 MSL(即,2 mins)

結(jié)論:幾個核心要點(diǎn)

  1. time_wait 狀態(tài)的影響:

  • TCP 連接中,「主動發(fā)起關(guān)閉連接」的一端,會進(jìn)入 time_wait 狀態(tài)

  • time_wait 狀態(tài),默認(rèn)會持續(xù) 2 MSL(報文的最大生存時間),一般是 2x2 mins

  • time_wait 狀態(tài)下,TCP 連接占用的端口,無法被再次使用

  • TCP 端口數(shù)量,上限是 6.5w(65535,16 bit)

  • 大量 time_wait 狀態(tài)存在,會導(dǎo)致新建 TCP 連接會出錯,address already in use : connect 異常

  • 現(xiàn)實(shí)場景:

  • 服務(wù)器端,一般設(shè)置:不允許「主動關(guān)閉連接」

  • 但 HTTP 請求中,http 頭部 connection 參數(shù),可能設(shè)置為 close,則,服務(wù)端處理完請求會主動關(guān)閉 TCP 連接

  • 現(xiàn)在瀏覽器中, HTTP 請求 connection 參數(shù),一般都設(shè)置為 keep-alive

  • Nginx 反向代理場景中,可能出現(xiàn)大量短鏈接,服務(wù)器端,可能存在

  • 解決辦法:

  • 服務(wù)器端允許 time_wait 狀態(tài)的 socket 被重用

  • 縮減 time_wait 時間,設(shè)置為 1 MSL(即,2 mins)

附錄

幾個方面:
  1. TCP 連接狀態(tài)的查詢

  2. MSL 時間

  3. TCP 三次握手和四次握手

附錄 A:查詢 TCP 連接狀態(tài)Mac 下,查詢 TCP 連接狀態(tài)的具體命令:

	

		// Mac 下,查詢 TCP 連接狀態(tài)$ netstat -nat |grep TIME_WAIT // Mac 下,查詢 TCP 連接狀態(tài),其中 -E 表示 grep 或的匹配邏輯$ netstat -nat | grep -E "TIME_WAIT|Local Address"Proto Recv-Q Send-Q Local Address Foreign Address (state)tcp4 0 0 127.0.0.1.1080 127.0.0.1.59061 TIME_WAIT // 統(tǒng)計(jì):各種連接的數(shù)量$ netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'ESTABLISHED 1154TIME_WAIT 1645附錄 B:MSL 時間 MSL,Maximum Segment Lifetime,“報文最大生存時間”
  1. 任何報文在網(wǎng)絡(luò)上存在的最長時間,超過這個時間報文將被丟棄。(IP 報文)

  2. TCP報文 (segment)是ip數(shù)據(jù)報(datagram)的數(shù)據(jù)部分。

Tips:RFC 793中規(guī)定MSL為2分鐘,實(shí)際應(yīng)用中常用的是30秒,1分鐘和2分鐘等。2MSL,TCP 的 TIME_WAIT 狀態(tài),也稱為2MSL等待狀態(tài):
  1. 當(dāng)TCP的一端發(fā)起主動關(guān)閉(收到 FIN 請求),在發(fā)出最后一個ACK 響應(yīng)后,即第3次握 手完成后,發(fā)送了第四次握手的ACK包后,就進(jìn)入了TIME_WAIT狀態(tài)。

  2. 必須在此狀態(tài)上停留兩倍的MSL時間,等待2MSL時間主要目的是怕最后一個 ACK包對方?jīng)]收到,那么對方在超時后將重發(fā)第三次握手的FIN包,主動關(guān)閉端接到重發(fā)的FIN包后,可以再發(fā)一個ACK應(yīng)答包。

  3. 在 TIME_WAIT 狀態(tài)時,兩端的端口不能使用,要等到2MSL時間結(jié)束,才可繼續(xù)使用。(IP 層)

  4. 當(dāng)連接處于2MSL等待階段時,任何遲到的報文段都將被丟棄。 不過在實(shí)際應(yīng)用中,可以通過設(shè)置 「SO_REUSEADDR選項(xiàng)」,達(dá)到不必等待2MSL時間結(jié)束,即可使用被占用的端口。

附錄 C:TCP 三次握手和四次握手 具體示意圖:
  1. 三次握手,建立連接過程

  2. 四次揮手,釋放連接過程

cfdcc5d4-28d3-11ed-ba43-dac502259ad0.png ?

良許花了一個半月的時間研發(fā)了一門 Linux 命令課程,歡迎購買學(xué)習(xí)!

審核編輯 :李倩


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 服務(wù)器
    +關(guān)注

    關(guān)注

    14

    文章

    10253

    瀏覽量

    91484
  • TCP
    TCP
    +關(guān)注

    關(guān)注

    8

    文章

    1425

    瀏覽量

    83504

原文標(biāo)題:服務(wù)端 TCP 連接TIME_WAIT怎么破?77%的人都不知道~

文章出處:【微信號:良許Linux,微信公眾號:良許Linux】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    Linux新手必看!3個命令搞定所有“求助”,再也不用到處查文檔

    其實(shí)根本不用慌——Linux 早就自帶了 “說明書”,學(xué)會 3 個核心幫助命令,就能解決 90% 的操作疑問,比百度還快!
    的頭像 發(fā)表于 02-03 15:28 ?702次閱讀
    <b class='flag-5'>Linux</b>新手必看!3個<b class='flag-5'>命令</b>搞定所有“求助”,再也不用到處查文檔

    Linux 下開發(fā)嵌入式必備命令速查表

    在嵌入式開發(fā)中,Linux系統(tǒng)幾乎成為必備的開發(fā)環(huán)境。不管你是在做STM32、RaspberryPi、還是基于ARM的板子,熟練掌握Linux命令不僅能加快開發(fā)效率,還能讓你在調(diào)試、交叉編譯、文件
    的頭像 發(fā)表于 01-19 09:06 ?881次閱讀
    <b class='flag-5'>Linux</b> 下開發(fā)嵌入式必備<b class='flag-5'>命令</b>速查表

    學(xué)習(xí)Linux應(yīng)該從哪里開始?

    在工業(yè)控制、邊緣計(jì)算、人工智能這些領(lǐng)域,有一句幾乎約定俗成的話: “會不會 Linux,決定了你能走多遠(yuǎn)?!?但對很多剛?cè)腴T的工程師來說,Linux 看起來像個龐大又神秘的世界——命令行、驅(qū)動、內(nèi)核
    的頭像 發(fā)表于 10-16 09:51 ?453次閱讀
    <b class='flag-5'>學(xué)習(xí)</b><b class='flag-5'>Linux</b>應(yīng)該從哪里開始?

    Linux基礎(chǔ)命令的進(jìn)階用法

    凌晨2點(diǎn),正在熟睡的你被電話驚醒:"線上服務(wù)響應(yīng)超時,用戶大面積投訴!" 你匆忙打開電腦,SSH 登錄服務(wù)器,面對滿屏的進(jìn)程和日志,腦子一片空白——從哪里開始排查?用什么命令?怎么快速定位問題?
    的頭像 發(fā)表于 09-02 16:33 ?693次閱讀

    測試工程師都在用的Linux命令清單(建議收藏)

    作為一名工程師,熟練掌握Linux命令是基本功中的基本功。無論是日常工作中的系統(tǒng)維護(hù),還是面試時的技術(shù)考核,Linux命令都是繞不開的核心技能。本文將從實(shí)戰(zhàn)角度出發(fā),系統(tǒng)梳理工程師必須
    的頭像 發(fā)表于 08-08 10:06 ?697次閱讀
    測試工程師都在用的<b class='flag-5'>Linux</b><b class='flag-5'>命令</b>清單(建議收藏)

    【「Yocto項(xiàng)目實(shí)戰(zhàn)教程:高效定制嵌入式Linux系統(tǒng)」閱讀體驗(yàn)】+基礎(chǔ)概念學(xué)習(xí)理解

    系統(tǒng)的基礎(chǔ)知識,及yocto的基礎(chǔ)知識。這部分內(nèi)容對于我這樣有一定 Linux 基礎(chǔ)的讀者來說,起到了很好的復(fù)習(xí)和鞏固作用,同時也為后續(xù)學(xué)習(xí) Yocto 項(xiàng)目奠定了堅(jiān)實(shí)的理論基礎(chǔ)。 元數(shù)據(jù) 元數(shù)據(jù)架構(gòu)
    發(fā)表于 08-04 22:29

    Linux基礎(chǔ)命令which詳解

    Linux系統(tǒng)中,which命令用于查找并顯示指定命令的可執(zhí)行文件路徑。這對于系統(tǒng)管理員和開發(fā)人員來說是一個非常有用的工具,可以幫助定位命令所在的位置,確認(rèn)
    的頭像 發(fā)表于 07-29 17:58 ?851次閱讀

    linux系統(tǒng)awk特殊字符命令詳解

    Linux系統(tǒng)中,awk?是一種非常強(qiáng)大的文本處理工具,能夠?qū)ξ谋緮?shù)據(jù)進(jìn)行分析、格式化和篩選。利用其內(nèi)置的特殊字符和操作符,用戶可以實(shí)現(xiàn)復(fù)雜的數(shù)據(jù)處理任務(wù)。以下對一些常見的awk特殊字符和操作符
    的頭像 發(fā)表于 07-28 16:38 ?639次閱讀

    已收藏!你需要知道的57個常用樹莓派命令!

    ,下面我們將按類別介紹57個最常用的命令:目錄文件管理網(wǎng)絡(luò)命令系統(tǒng)更新包管理系統(tǒng)管理樹莓派操作系統(tǒng)命令雜項(xiàng)命令高級命令這份列表是基于我與樹莓
    的頭像 發(fā)表于 07-23 18:36 ?1140次閱讀
    已收藏!你需要知道的57個常用樹莓派<b class='flag-5'>命令</b>!

    一文掌握Linux命令

    作為一名運(yùn)維工程師,熟練掌握Linux命令是基本功中的基本功。無論是日常工作中的系統(tǒng)維護(hù),還是面試時的技術(shù)考核,Linux命令都是繞不開的核心技能。本文將從實(shí)戰(zhàn)角度出發(fā),系統(tǒng)梳理運(yùn)維工
    的頭像 發(fā)表于 07-22 15:23 ?613次閱讀

    Linux系統(tǒng)管理的核心概念

    在前一篇文章中,我們深入探討了Linux中的文件操作命令,如cp、mv、rm,以及文本處理命令grep、wc和管道符。本文將繼續(xù)深入Linux系統(tǒng)管理的核心概念,包括root用戶的角色
    的頭像 發(fā)表于 05-15 17:05 ?663次閱讀

    為什么無法在Linux SDK中找到重置端點(diǎn)和中止端點(diǎn)功能的等效命令?

    你好,我有客戶正在使用 Linux 開發(fā)他們的軟件界面。 我們的窗口應(yīng)用程序可以運(yùn)行,但他們想轉(zhuǎn)換到 Linux。 他們無法在 Linux SDK 中找到重置端點(diǎn)和中止端點(diǎn)功能的等效命令
    發(fā)表于 05-07 07:24

    Linux常用命令大全

    Linux常用命令是指在Linux操作系統(tǒng)中廣泛使用的命令工具,這些命令工具可以完成各種不同的任務(wù),如管理文件和目錄、操作進(jìn)程、網(wǎng)絡(luò)通信、軟
    的頭像 發(fā)表于 05-03 18:08 ?1864次閱讀

    5個Linux性能監(jiān)控命令

    vmstat 命令可打印有關(guān)內(nèi)存、交換、I/O 和 CPU 活動的詳細(xì)報告。其中包括已用/可用內(nèi)存、交換入/出、磁盤塊讀/寫和 CPU 進(jìn)程/閑置時間等指標(biāo)。
    的頭像 發(fā)表于 04-09 10:34 ?815次閱讀

    Linux下Vim編輯器的使用技巧

    【Vim】常用總結(jié)? 簡介? image 什么是vim?? Linux下兩大編輯神器之一 vim ? Linux/Unix下使用最多的編輯器 ? vi的改進(jìn)版 ? 可能是最難上手的編輯器之一
    的頭像 發(fā)表于 04-01 17:36 ?1429次閱讀
    <b class='flag-5'>Linux</b>下Vim編輯器的使用技巧