前言
瀏覽器(IE,火狐,谷歌等)和apache都是基于http協(xié)議進(jìn)行通訊的。瀏覽器在客戶端,apache在服務(wù)端。http協(xié)議是在TCP/IP模型中的應(yīng)用層。TCP協(xié)議狀態(tài)在TCP/IP模型中的傳輸層。在瀏覽一個(gè)網(wǎng)站的時(shí)候,如果關(guān)閉了瀏覽器,只是關(guān)閉了瀏覽器的進(jìn)程,瀏覽器和apache之間的連接還沒(méi)有完全斷開。操作系統(tǒng)會(huì)在一定時(shí)間后自動(dòng)斷開該連接。服務(wù)端也是一樣,雖然apache的進(jìn)程已經(jīng)關(guān)閉了,但是連接不會(huì)立刻斷開,linux操作系統(tǒng)會(huì)在一定時(shí)間后斷開該連接。
TCP/IP結(jié)構(gòu)對(duì)應(yīng)OSI結(jié)構(gòu)
TCP/IPOSI功能TCP/IP協(xié)議族應(yīng)用層應(yīng)用層文件傳輸,電子郵件,文件服務(wù),虛擬終端TFTP,HTTP,SNMP,F(xiàn)TP,SMTP,DNS,RIP,Telnet 表示層數(shù)據(jù)格式化,代碼轉(zhuǎn)換,數(shù)據(jù)加密沒(méi)有協(xié)議 會(huì)話層解除或建立與別的接點(diǎn)的聯(lián)系沒(méi)有協(xié)議傳輸層傳輸層提供端對(duì)端的接口TCP,UDP網(wǎng)絡(luò)層網(wǎng)絡(luò)層為數(shù)據(jù)包選擇路由IP,ICMP,OSPF,BGP,IGMP,ARP,RARP鏈路層鏈路層傳輸有地址的幀以及錯(cuò)誤檢測(cè)功能SLIP,CSLIP,PPP,MTU,ARP,RARP 物理層以二進(jìn)制數(shù)據(jù)形式在物理媒體上傳輸數(shù)據(jù)ISO2110,IEEE802,IEEE802.2
那么當(dāng)完成數(shù)據(jù)傳輸后操作系統(tǒng)是怎么斷開該連接的?下面詳細(xì)講解這個(gè)連接和斷開過(guò)程。
首先了解TCP協(xié)議的幾種狀態(tài)
LISTEN:偵聽來(lái)自遠(yuǎn)方的TCP端口 的連接請(qǐng)求
SYN-SENT:再發(fā)送連接請(qǐng)求后等待匹配的連接請(qǐng)求
SYN-RECEIVED:再收到和發(fā)送一個(gè)連接請(qǐng)求后等待對(duì)方對(duì)連接 請(qǐng)求的確認(rèn)
ESTABLISHED:代表一個(gè)打開的連接
FIN-WAIT-1:等待遠(yuǎn)程TCP連接中斷請(qǐng)求,或先前的連接中斷請(qǐng)求的確認(rèn)
FIN- WAIT-2:從遠(yuǎn)程TCP等待連接中斷請(qǐng)求
CLOSE-WAIT:等待從本地用戶發(fā)來(lái)的連接中斷請(qǐng)求
CLOSING:等待遠(yuǎn)程TCP對(duì) 連接中斷的確認(rèn)
LAST-ACK:等待原來(lái)的發(fā)向遠(yuǎn)程TCP的連接中斷請(qǐng)求的確認(rèn)
TIME-WAIT:等待足夠的時(shí)間以確保遠(yuǎn)程TCP接 收到連接中斷請(qǐng)求的確認(rèn)
CLOSED:沒(méi)有任何連接狀態(tài)
發(fā)起連接請(qǐng)求
apache服務(wù)器(服務(wù)端)不會(huì)主動(dòng)發(fā)起連接請(qǐng)求的,apache服務(wù)器一直監(jiān)聽80端口(設(shè)定的某個(gè)端口),一旦有連接請(qǐng)求就會(huì)對(duì)請(qǐng)求作出響應(yīng)。
所以每次的連接都是從瀏覽器(客戶端)發(fā)起的。而關(guān)閉連接請(qǐng)求有可能是apache服務(wù)器發(fā)給瀏覽器,也有可能是瀏覽器發(fā)送給apache服務(wù)器。
瀏覽器發(fā)起關(guān)閉連接請(qǐng)求
瀏覽器在什么情況是會(huì)發(fā)起關(guān)閉連接請(qǐng)求?
1,所有的數(shù)據(jù)傳輸完成。
2,關(guān)閉了瀏覽器
3,其他
瀏覽器發(fā)起關(guān)閉連接請(qǐng)求的TCP協(xié)議狀態(tài)遷移圖
每個(gè)步驟的說(shuō)明:
1,瀏覽中輸入網(wǎng)址,開始連接服務(wù)器。這時(shí)瀏覽器的狀態(tài)是SYN_SENT,apache的狀態(tài)是LISTEN。
2,apache收到連接請(qǐng)求,開始一些準(zhǔn)備工作,比如為該連接開辟內(nèi)存空間,建立進(jìn)程,并回復(fù)瀏覽器確認(rèn)連接。這時(shí)瀏覽器的狀態(tài)是SYN_SENT,apache的狀態(tài)是SYN_RCVD。
3,瀏覽收到連接確認(rèn),連接被成功建立,開始請(qǐng)求需要的數(shù)據(jù)。這時(shí)瀏覽器的狀態(tài)是ESTABLISHED,apache的狀態(tài)是SYN_RECVD。
4,apache收到數(shù)據(jù)請(qǐng)求,發(fā)送相應(yīng)的數(shù)據(jù)給瀏覽器。這時(shí)瀏覽器的狀態(tài)是ESTABLISHED,apache的狀態(tài)也是ESTABLISHED。
5,瀏覽器繼續(xù)請(qǐng)求需要的數(shù)據(jù)。這時(shí)瀏覽器的狀態(tài)是ESTABLISHED,apache的狀態(tài)也是ESTABLISHED。
6,apache收到數(shù)據(jù)請(qǐng)求,發(fā)送響應(yīng)的數(shù)據(jù)給瀏覽器。這時(shí)瀏覽器的狀態(tài)是ESTABLISHED,apache的狀態(tài)也是ESTABLISHED。
。。。。。
。。。。。
重復(fù)5和6直到所有數(shù)據(jù)接收完成
7,瀏覽器判斷所有數(shù)據(jù)接收完畢,發(fā)送關(guān)閉連接請(qǐng)求。這時(shí)瀏覽器的狀態(tài)是FIN_WAIT_1,apache 的狀態(tài)是ESTABLISHED。
8,apache收到關(guān)閉連接請(qǐng)求,開始關(guān)閉連接工作(只是開始,并不是準(zhǔn)備工作全部完成),比如關(guān)閉內(nèi)存空間,關(guān)閉進(jìn)程等,并發(fā)送同意關(guān)閉連接。這時(shí)瀏覽器的狀態(tài)是FIN_WAIT_1,apache的狀態(tài)是CLOSED_WAIT。
9,瀏覽器收到同意關(guān)閉連接,瀏覽器不會(huì)再發(fā)送請(qǐng)求,只是等待,開始等待apache的關(guān)閉工作完成,開始等待apache完成關(guān)閉工作后的確認(rèn)。這時(shí)瀏覽器的狀態(tài)是FIN_WAIT_2,apache的狀態(tài)是CLOSE_WAIT。
10,apache完成關(guān)閉工作,內(nèi)存回收,關(guān)閉進(jìn)程等,發(fā)送最后的關(guān)閉確認(rèn)請(qǐng)求。這時(shí)瀏覽器的狀態(tài)是FIN_WAIT_2,apache的狀態(tài)是LAST_ACK。
11,瀏覽器收到最后的關(guān)閉確認(rèn),關(guān)閉連接,并發(fā)送最后的關(guān)閉連接應(yīng)答。這時(shí)會(huì)有2*SML秒的緩沖時(shí)間。2*SML時(shí)間后連接正式關(guān)閉。SML時(shí)間根據(jù)操作系統(tǒng)不一樣而不一樣。centos的SML時(shí)間是30秒。這時(shí)瀏覽器的狀態(tài)時(shí)TIME_WAIT,apache的狀態(tài)是LAST_ACK。
12,apache收到最后的關(guān)閉連接應(yīng)答,apache關(guān)閉連接。這時(shí)也會(huì)有2*SML秒的緩沖時(shí)間。2*SML后連接正式關(guān)閉。這時(shí)瀏覽器的狀態(tài)是TIME_WAIT,apache的狀態(tài)是TIME_WAIT。
13,2*SML秒后瀏覽器的狀態(tài)時(shí)CLOSED,apache的狀態(tài)也是CLOSED。
apache發(fā)起關(guān)閉連接請(qǐng)求
apache在什么情況下會(huì)發(fā)起關(guān)閉連接請(qǐng)求呢?
1,http.conf 里面有個(gè)參數(shù)time_out。這個(gè)值是完成上一個(gè)請(qǐng)求的應(yīng)答之后和下一個(gè)請(qǐng)求到來(lái)的時(shí)間差。如果apache在完成上一個(gè)請(qǐng)求的應(yīng)答之后等了time_out秒還沒(méi)收到第二個(gè)連接,apache就會(huì)主動(dòng)斷開該連接。
2,apache內(nèi)存耗盡,或者一些其他原因
apache發(fā)起關(guān)閉連接請(qǐng)求的TCP狀態(tài)遷移圖
每個(gè)步驟的說(shuō)明:
1,瀏覽中輸入網(wǎng)址,開始連接服務(wù)器。這時(shí)瀏覽器的狀態(tài)是SYN_SENT,apache的狀態(tài)是LISTEN。
2,apache收到連接請(qǐng)求,開始一些準(zhǔn)備工作,比如為該連接開辟內(nèi)存空間,建立進(jìn)程,并回復(fù)瀏覽器確認(rèn)連接。這時(shí)瀏覽器的狀態(tài)是SYN_SENT,apache的狀態(tài)是SYN_RCVD。
3,瀏覽收到連接確認(rèn),連接被成功建立,開始請(qǐng)求需要的數(shù)據(jù)。這時(shí)瀏覽器的狀態(tài)是ESTABLISHED,apache的狀態(tài)是SYN_RECVD。
4,apache收到數(shù)據(jù)請(qǐng)求,發(fā)送相應(yīng)的數(shù)據(jù)給瀏覽器。這時(shí)瀏覽器的狀態(tài)是ESTABLISHED,apache的狀態(tài)也是ESTABLISHED。
5,瀏覽器繼續(xù)請(qǐng)求需要的數(shù)據(jù)。這時(shí)瀏覽器的狀態(tài)是ESTABLISHED,apache的狀態(tài)也是ESTABLISHED。
6,apache收到數(shù)據(jù)請(qǐng)求,發(fā)送響應(yīng)的數(shù)據(jù)給瀏覽器。這時(shí)瀏覽器的狀態(tài)是ESTABLISHED,apache的狀態(tài)也是ESTABLISHED。
。。。。。
。。。。。
重復(fù)5和6直到所有數(shù)據(jù)接收完成
7,apache等待time_out秒后沒(méi)有收到下個(gè)請(qǐng)求,所以主動(dòng)發(fā)起關(guān)閉連接請(qǐng)求。這時(shí)瀏覽器的狀態(tài)是ESTABLISHED,apache的狀態(tài)是FIN_WAIT_1。
8,瀏覽器收到關(guān)閉連接請(qǐng)求,開始關(guān)閉連接工作(只是開始,并不是準(zhǔn)備工作全部完成),比如關(guān)閉內(nèi)存空間,關(guān)閉進(jìn)程等,并發(fā)送同意關(guān)閉連接。這時(shí)瀏覽器的狀態(tài)是CLOSED_WAIT,apache的狀態(tài)是FIN_WAIT_1。
9,apache收到同意關(guān)閉連接,apache不會(huì)再發(fā)送請(qǐng)求,只是等待,開始等待瀏覽器的關(guān)閉工作完成,開始等待瀏覽器完成關(guān)閉工作后的確認(rèn)。這時(shí)瀏覽器的狀態(tài)是CLOSED_WAIT,apache的狀態(tài)是FIN_WAIT_2。
10,瀏覽器完成關(guān)閉工作,內(nèi)存回收,關(guān)閉進(jìn)程等,發(fā)送最后的關(guān)閉確認(rèn)請(qǐng)求。這時(shí)瀏覽器的狀態(tài)是LAST_ACK,apache的狀態(tài)是FIN_WAIT_2。
11,apache收到最后的關(guān)閉確認(rèn),關(guān)閉連接,并發(fā)送最后的關(guān)閉連接應(yīng)答。這時(shí)會(huì)有2*SML秒的緩沖時(shí)間。2*SML時(shí)間后連接正式關(guān)閉。這時(shí)瀏覽器的狀態(tài)時(shí)LAST_ACK,apache的狀態(tài)是TIME_WAIT。
12,瀏覽器收到最后的關(guān)閉連接應(yīng)答,瀏覽器關(guān)閉連接。這時(shí)也會(huì)有2*SML秒的緩沖時(shí)間。2*SML后連接正式關(guān)閉。這時(shí)瀏覽器的狀態(tài)是TIME_WAIT,apache的狀態(tài)也是TIME_WAIT。
13,2*SML秒后瀏覽器的狀態(tài)時(shí)CLOSED,apache的狀態(tài)也是CLOSED。
查看apache的連接狀態(tài)
linux下查看所有連接狀態(tài)的命令為:
#netstat -nat
linux下查看所有TCP連接數(shù)的統(tǒng)計(jì):
#netstat -nat|awk ‘{print awk $NF}’|sort|uniq -c|sort –n
linux下查看80端口的連接數(shù)的統(tǒng)計(jì):
#netstat -nat|grep “:80″|awk ‘{print $5}’ |awk -F: ‘{print $1}’ | sort| uniq -c|sort -n
linux下查看apache的連接狀態(tài)的命令為:
#netstat -nat|grep –i ’80′
linux下查看apache的某個(gè)狀態(tài)的命令為:
#netstat -nat|grep LISTEN
#netstat -nat|grep ESTABLISHED
#netstat -nat|grep TIME_WAIT
。。。。。。。。對(duì)應(yīng)的TCP協(xié)議狀態(tài)
linux下查看apache的所有相關(guān)連接狀態(tài)的命令為:
#netstat -n |awk ‘/^tcp/ {++S[$NF]} END {for(a in S)print a,S[a]}’
該命令非常實(shí)用,會(huì)列出apache的所有連接狀態(tài)信息的統(tǒng)計(jì)。如果某個(gè)狀態(tài)沒(méi)有連接則不顯示。
補(bǔ)充:
本篇文章是為以后編寫關(guān)于apache,mysql并發(fā)優(yōu)化的輔助文章,是最基礎(chǔ)的知識(shí)。是本人對(duì)瀏覽器與apache的TCP連接狀態(tài)的一些理解,難免會(huì)有一些錯(cuò)誤。但是作為一個(gè)程序員如果理解上面這些內(nèi)容足以。更多的細(xì)節(jié)內(nèi)容應(yīng)該是架構(gòu)師的事情了。
本文地址:http://www.qindamoni.com/84
新聞熱點(diǎn)
疑難解答