|
|
Nginx
|
|
路由到 www.test.com/index.php
|
|
加載 nginx 的 fast-cgi 模塊
|
|
fast-cgi 監(jiān)聽 127.0.0.1:9000 地址
|
|
www.test.com/index.php 請求到達(dá) 127.0.0.1:9000
|
|
等待處理…
Nginx 與 php-fpm 的結(jié)合
在 Linux 上,nginx 與 php-fpm 的通信有 tcp socket 和 unix socket 兩種方式。
tcp socket 的優(yōu)點(diǎn)是可以跨服務(wù)器,當(dāng) nginx 和 php-fpm 不在同一臺機(jī)器上時(shí),只能使用這種方式。
Unix socket 又叫 IPC(inter-process communication 進(jìn)程間通信) socket,用于實(shí)現(xiàn)同一主機(jī)上的進(jìn)程間通信,這種方式需要在 nginx配置文件中填寫 php-fpm 的 socket 文件位置。
兩種方式的數(shù)據(jù)傳輸過程如下圖所示:
二者的不同:
由于 Unix socket 不需要經(jīng)過網(wǎng)絡(luò)協(xié)議棧,不需要打包拆包、計(jì)算校驗(yàn)和、維護(hù)序號和應(yīng)答等,只是將應(yīng)用層數(shù)據(jù)從一個(gè)進(jìn)程拷貝到另一個(gè)進(jìn)程。所以其效率比 tcp socket 的方式要高,可減少不必要的 tcp 開銷。不過,unix socket 高并發(fā)時(shí)不穩(wěn)定,連接數(shù)爆發(fā)時(shí),會產(chǎn)生大量的長時(shí)緩存,在沒有面向連接協(xié)議的支撐下,大數(shù)據(jù)包可能會直接出錯(cuò)不返回異常。而 tcp 這樣的面向連接的協(xié)議,可以更好的保證通信的正確性和完整性。
Nginx 與 php-fpm 結(jié)合只需要在各自的配置文件中做設(shè)置即可:
1) Nginx 中的配置
以 tcp socket通信為例
server { listen 80; #監(jiān)聽 80 端口,接收http請求 server_name www.test.com; #就是網(wǎng)站地址 root /usr/local/etc/nginx/www/huxintong_admin; # 準(zhǔn)備存放代碼工程的路徑 #路由到網(wǎng)站根目錄 www.test.com 時(shí)候的處理 location / { index index.php; #跳轉(zhuǎn)到 www.test.com/index.php autoindex on; } #當(dāng)請求網(wǎng)站下 php 文件的時(shí)候,反向代理到 php-fpm location ~ \.php$ { include /usr/local/etc/nginx/fastcgi.conf; #加載 nginx 的 fastcgi 模塊 fastcgi_intercept_errors on; fastcgi_pass 127.0.0.1:9000; # tcp 方式,php-fpm 監(jiān)聽的 IP 地址和端口 # fasrcgi_pass /usr/run/php-fpm.sock # unix socket 連接方式 } }
2) php-fpm 的配置
listen = 127.0.0.1:9000 # 或者下面這樣 listen = /var/run/php-fpm.sock
注意,在使用 unix socket 方式連接時(shí),由于 socket 文件本質(zhì)上是一個(gè)文件,存在權(quán)限控制的問題,所以需要注意 nginx 進(jìn)程的權(quán)限與 php-fpm 的權(quán)限問題,不然會提示無權(quán)限訪問。(在各自的配置文件里設(shè)置用戶)
通過以上配置即可完成 php-fpm 與 nginx 的通信。
在應(yīng)用中的選擇
如果是在同一臺服務(wù)器上運(yùn)行的 nginx 和 php-fpm,且并發(fā)量不高(不超過1000),選擇unix socket,以提高 nginx 和 php-fpm 的通信效率。
如果是面臨高并發(fā)業(yè)務(wù),則考慮選擇使用更可靠的 tcp socket,以負(fù)載均衡、內(nèi)核優(yōu)化等運(yùn)維手段維持效率。
若并發(fā)較高但仍想用 unix socket 時(shí),可通過以下方式提高 unix socket 的穩(wěn)定性。
1)將sock文件放在 /dev/shm 目錄下,此目錄下將 sock 文件放在內(nèi)存里面,內(nèi)存的讀寫更快。
2)提高 backlog
backlog 默認(rèn)位 128,1024 這個(gè)值最好換算成自己正常的 QPS,配置如下。
nginx.conf 文件中
server { listen 80 default backlog = 1024; }
php-fpm.conf 文件中
listen.backlog = 1024
3)增加 sock 文件和 php-fpm 實(shí)例
在 /dev/shm 新建一個(gè) sock 文件,在 nginx 中通過 upstream 模塊將請求負(fù)載均衡到兩個(gè) sock 文件,并且將兩個(gè) sock 文件分別對應(yīng)到兩套 php-fpm 實(shí)例上。