成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

HTTP、PHP-FPM、與握手協(xié)議

superw / 3659人閱讀

摘要:一般產(chǎn)生的原因是系統(tǒng)沒有主動關閉連接如連接資源沒有關閉關于網(wǎng)絡鏈路中追蹤異常用到的運維命令以下顯示的和端口均為假數(shù)據(jù)中查看的狀態(tài)參數(shù)說明已使用的所有協(xié)議套接字總量正在使用正在偵聽的套接字數(shù)量。其值等于已分配已建立已申請到的套接字數(shù)量。

HTTP請求的流程梳理

用戶輸入url如http:www.baidu.com到瀏覽器,瀏覽器如chrom需要將其解析為ip地址才知道需要到哪里去訪問哪個服務器。瀏覽器解析DNS步驟如下

搜索瀏覽器自身的dns緩存,這個緩存緩存時間短,緩存數(shù)目有限。

搜索操作系統(tǒng)的dns緩存

讀取host文件的dns映射(一般做本地開發(fā)映射都是修改這個文件來達到攔截瀏覽器請求到本地服務器的目的,從而使本地可以成功映射服務器地址)

先本地網(wǎng)卡配置里的dns服務器發(fā)起域名解析請求,這里好像還有一套運營商的處理流程就不在展開了。

下面好像還有一些流程,由于基本不會執(zhí)行到這一步,一般所以dns運營商的dns服務器都會搞定的。

解析失敗,以上任何一步成功都會返回一個成功的ip地址

瀏覽器以一個隨機的端口享這個ip地址的特定端口(默認80)發(fā)起著名的TCP3次握手。關于一個http請求是如何到達nginx服務的流程大致如下:

握手完成后的瀏覽器和服務器就可以愉快地發(fā)送http請求了,具體在nginx上流程如下:

PHP-FPM在服務端出來請求中扮演了什么角色

PHP、nginx與CGI協(xié)議

對于一個PHP的web程序來說,web服務器(如:nginx)要想與它通信需要通過CGI協(xié)議。當一個web請求觸達web服務器時,web服務器會創(chuàng)建一個CGI進程,CGI進程將web的請求按照固定的格式進行解析,然后寫入標準輸入(STDIN)和環(huán)境變量中,然后PHP啟動的CGI解析器會從標準輸入(STDIN)和環(huán)境變量中讀取http請求的數(shù)據(jù),所以$_SERVER才會有數(shù)據(jù),然后做出相應的邏輯處理,然后將處理結果放入標準輸出(STDOUT),CGI進程從STDOUT中讀取響應數(shù)據(jù)然后傳輸給瀏覽器,這樣服務端就完成了一次http請求。

上面是CGI的實現(xiàn)流程,但是使用CGI協(xié)議的服務器在用戶每次訪問服務器的時候都需要fork/銷毀CGI進程,必然照成多余的系統(tǒng)開銷,所以FASTCGI就是為了解決這個問題的。

什么是FastCGI協(xié)議

FastCGI會創(chuàng)建一個常駐的master進程和多個worker進程,master進程負責管理和為worker進程反派任務,worker進程負責內(nèi)部嵌入了CGI解析器用于解釋php代碼。

PHP-FPM是一個FastCGI進程管理器,在LNMP體系中就是由它來實現(xiàn)FastCGI協(xié)議的。同樣,它也會創(chuàng)建一個常駐的master進程和多個worker進程,master進程負責監(jiān)聽端口和接收來自nginx的請求,指派任務給worker進程。worker進程的負責解釋php代碼。PHP-FPM可以通過配置預先啟動一定數(shù)量的worker進程,這樣當http請求觸達時就可以更快速的響應。

Nginx關于FastCGI的配置

nginx與PHP-FPM之間的通信一般通過其ngx_http_fastcgi_module模塊來實現(xiàn)。其中fastcgi_pass用于設置fastcgi服務器的IP地址;fastcgi_param設置傳入fastcgi服務器的參數(shù)。這個模塊出現(xiàn)的配置問題一般集中在這一塊。

相對于并發(fā)狀態(tài)下出現(xiàn)的問題,一般也都集中在fastcgi服務器上,具體表現(xiàn)為fastcgi服務器為了應對大量的http請求必須不停的fork新的worker進程,這時就需要考慮服務器可支持的最大鏈接數(shù)和最大打開文件數(shù)(可通過ulimit -n查看)以及php-fpm配置里的最低開啟worker數(shù)和最高開啟worker數(shù)的限制。高性能服務器可以在這個方向上調(diào)優(yōu)。

HTTP協(xié)議三次握手四次揮手的細節(jié)

協(xié)議過程中客服端與服務端的狀態(tài)圖

TCP的標志位說明
標志位 英文 說明
SYN synchronous 建立聯(lián)機
ACK acknowledgement 確認
PSH push 傳送
FIN finish 結束
RST reset 重置
URG urgent 緊急
Sequence numbe - 順序號碼
Acknowledge number - 確認號碼

TCP狀態(tài)說明
狀態(tài) 說明
LISTEN 偵聽狀態(tài)
SYN_SEND 發(fā)送連接請求[SYN=J]后等待匹配連接請求
SYN_RECEIVED 收到連接請求[SYN=J]后發(fā)送連接確認包[SYN=k,ack=J+1]后等待收到確認包[Ack=k+1]狀態(tài)
ESTABLISHED 打開連接后,可以開始傳輸數(shù)據(jù)
FIN_WAIT_1 發(fā)起連接中斷請求[FIN=M]后等待遠程TCP確認時[Ack=M+1]狀態(tài)
FIN_WAIT_2 收到遠程中斷確認[Ack=M+1]后,等待遠程中斷請求[FIN=N]
CLOSE_WAIT 收到連接中斷請求[FIN=M]后未發(fā)送出中斷確認包[Ack=M=1]狀態(tài)
TIME_WAIT 發(fā)送確認遠程中斷請求[Ack=N+1]包后,進入等待狀態(tài),用以保證被重新分配的socket不會受到之前殘留的延遲重發(fā)報文影響的機制

大量TIME_WAIT的原因「常見性能異?!?/b>

在四次揮手斷開連接中,發(fā)起socket主動關閉的一方 socket將進入TIME_WAIT狀態(tài),TIME_WAIT狀態(tài)將持續(xù)2個MSL(Max Segment Lifetime),TIME_WAIT狀態(tài)下的socket不能被回收使用.

具體現(xiàn)象是對于一個處理大量短連接的服務器,如果是由服務器主動關閉客戶端的連接,將導致服務器端存在大量的處于TIME_WAIT狀態(tài)的socket, 甚至比處于Established狀態(tài)下的socket多的多,嚴重影響服務器的處理能力,甚至耗盡可用的socket,停止服務.

TIME_WAIT是TCP協(xié)議用以保證被重新分配的socket不會受到之前殘留的延遲重發(fā)報文影響的機制,是必要的邏輯保證。一般產(chǎn)生的原因是系統(tǒng)沒有主動關閉連接,如mysql連接資源沒有關閉

關于網(wǎng)絡鏈路中追蹤異常用到的運維命令

(以下顯示的IP和端口均為假數(shù)據(jù))

Linux中查看socket的狀態(tài)
cat /proc/net/sockstat

參數(shù) 說明
sockets:used 已使用的所有協(xié)議套接字總量
TCP:inuse 正在使用(正在偵聽)的TCP套接字數(shù)量。其值≤ netstat –lnt grep ^tcp wc –l
TCP:orphan 無主(不屬于任何進程)的TCP連接數(shù)(無用、待銷毀的TCP socket數(shù))
TCP:tw 等待關閉的TCP連接數(shù)。其值等于netstat –ant grep TIME_WAIT wc –l
TCP:alloc 已分配(已建立、已申請到sk_buff)的TCP套接字數(shù)量。其值等于netstat –ant grep ^tcp wc –l
TCP:mem 套接字緩沖區(qū)使用量
UDP:inuse 正在使用的UDP套接字數(shù)量
FRAG 使用的IP段數(shù)量

查看當前tcp鏈接情況
netstat -na | awk "/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}"

參數(shù) 說明
LISTEN 正在監(jiān)聽狀態(tài)
CLOSE_WAIT 對方主動關閉連接或者網(wǎng)絡異常導致連接中斷,這時我方的狀態(tài)會變成CLOSE_WAIT 此時我方要調(diào)用close()來使得連接正確關閉
ESTABLISHED 建立連接,正在通信
TIME_WAIT 我方主動調(diào)用close()斷開連接,收到對方確認后狀態(tài)變?yōu)門IME_WAIT

tcp工具抓取網(wǎng)絡請求包
tcpdump -n port 3306

mysql 主動斷開鏈接

11:38:45.693382 IP 172.18.0.3.3306 > 172.18.0.5.38822: Flags [F.], seq 123, ack 144, win 227, options [nop,nop,TS val 3000355 ecr 2997359], length 0 # MySQL發(fā)送fin包給我
11:38:45.740958 IP 172.18.0.5.38822 > 172.18.0.3.3306: Flags [.], ack 124, win 229, options [nop,nop,TS val 3000360 ecr 3000355], length 0 # 我回復ack給它
11:38:45.740960 IP 172.18.0.3.3306 > 172.18.0.5.38822: Flags [F.], ack 125, win 231, options [nop,nop,TS val 3000360 ecr 3000355], length 0 # MySQL發(fā)送fin包給客戶端
11:38:45.740965 IP 172.18.0.5.38822 > 172.18.0.3.3306: Flags [.], ack 125, win 229, options [nop,nop,TS val 3000360 ecr 3000355], length 0 # 客戶端回復ack給我
......

src > dst: flags data-seqno ack window urgent options
# 發(fā)生了 3次握手
11:38:15.679863 IP 172.18.0.5.38822 > 172.18.0.3.3306: Flags [S], seq 4065722321, win 29200, options [mss 1460,sackOK,TS val 2997352 ecr 0,nop,wscale 7], length 0
11:38:15.679923 IP 172.18.0.3.3306 > 172.18.0.5.38822: Flags [S.], seq 780487619, ack 4065722322, win 28960, options [mss 1460,sackOK,TS val 2997352 ecr 2997352,nop,wscale 7], length 0
11:38:15.679936 IP 172.18.0.5.38822 > 172.18.0.3.3306: Flags [.], ack 1, win 229, options [nop,nop,TS val 2997352 ecr 2997352], length 0
參數(shù) 說明
src > dst 表明從源地址到目的地址
flags 是TCP包中的標志信息,S 是SYN標志, F(FIN), P(PUSH) , R(RST) "."(沒有標記)
data-seqno 是數(shù)據(jù)包中的數(shù)據(jù)的順序號
ack 是下次期望的順序號
window 是接收緩存的窗口大小
urgent 表明數(shù)據(jù)包中是否有緊急指針
options 是選項

傳送門

文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/40370.html

相關文章

  • HTTP、PHP-FPM、握手協(xié)議

    摘要:一般產(chǎn)生的原因是系統(tǒng)沒有主動關閉連接如連接資源沒有關閉關于網(wǎng)絡鏈路中追蹤異常用到的運維命令以下顯示的和端口均為假數(shù)據(jù)中查看的狀態(tài)參數(shù)說明已使用的所有協(xié)議套接字總量正在使用正在偵聽的套接字數(shù)量。其值等于已分配已建立已申請到的套接字數(shù)量。 HTTP請求的流程梳理 用戶輸入url如http:www.baidu.com到瀏覽器,瀏覽器如chrom需要將其解析為ip地址才知道需要到哪里去訪問...

    gself 評論0 收藏0
  • career-tips | 踩坑路

    摘要:因為是多進程單線程同步模式,即一個子進程同時最多處理一個請求,所以子進程數(shù)等于最大并發(fā)數(shù)。 a little tips in my code career | 碼碼踩過的那些坑2015-2016 記一下這一年碼碼中我需要去了解的基礎知識,有不對的歡迎大家指證出來:https://github.com/TIGERB/car... 關于設計模式 關于PHP 關于互聯(lián)網(wǎng)協(xié)議 設計模...

    kviccn 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<