您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“nginx與php-fpm通信的方式有哪些”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“nginx與php-fpm通信的方式有哪些”這篇文章吧。
1.IP:Port 監(jiān)聽方式
php-fpm docker pull PHP:2.4-alpine nginx.conf fastcgi_pass 127.0.0.1:9000;
php-fpm 在容器里的 nginx.conf
location /php { proxy_set_header Host $host:$server_port; proxy_pass http://138.38.38.111:80/; }
2.UDS 方式監(jiān)聽
php-fpm listen = /tmp/php-fpm.sock nginx.conf fastcgi_pass unix:/tmp/php-fpm.sock;
3.注意
php-fpm用ip:port方式建立鏈接,
nginx不要用unix socket方式建立鏈接,用ip:port方式建立連接就行
下面看下nginx與php-fpm通信的兩種方式
在linux中,nginx服務(wù)器和php-fpm可以通過tcp socket和unix socket兩種方式實現(xiàn)。
unix socket是一種終端,可以使同一臺操作系統(tǒng)上的兩個或多個進程進行數(shù)據(jù)通信。這種方式需要再nginx配置文件中填寫php-fpm的pid文件位置,效率要比tcp socket高。
tcp socket的優(yōu)點是可以跨服務(wù)器,當nginx和php-fpm不在同一臺機器上時,只能使用這種方式。
windows系統(tǒng)只能使用tcp socket的通信方式
配置方法
tcp socket
tcp socket通信方式,需要在nginx配置文件中填寫php-fpm運行的ip地址和端口號。
location ~ \.php$ { include fastcgi_params; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; }
unix socket
unix socket通信方式,需要在nginx配置文件中填寫php-fpm運行的pid文件地址。
location ~ \.php$ { include fastcgi_params; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;; fastcgi_pass unix:/var/run/php5-fpm.sock; fastcgi_index index.php; }
php-fpm的運行端口號和socket文件的地址都是在php-fpm.conf中配置的。
php-fpm.conf文件在php安裝文件的/etc目錄下,
比如你的php安裝在/opt/php目錄,則應(yīng)該是/opt/php/php-fpm.conf。
; The address on which to accept FastCGI requests. ; Valid syntaxes are: ; 'ip.add.re.ss:port' - to listen on a TCP socket to a specific IPv4 address on ; a specific port; ; '[ip:6:addr:ess]:port' - to listen on a TCP socket to a specific IPv6 address on ; a specific port; ; 'port' - to listen on a TCP socket to all IPv4 addresses on a ; specific port; ; '[::]:port' - to listen on a TCP socket to all addresses ; (IPv6 and IPv4-mapped) on a specific port; ; '/path/to/unix/socket' - to listen on a unix socket. ; Note: This value is mandatory. listen = 127.0.0.1:9000 listen = /var/run/php-fpm.sock
通過注釋可以看到,php-fpm的listen指令可以通過五種方式處理FastCGI請求,分別是:
1. ipv4:端口號
2. ipv6:端口號
3. port相當于 0.0.0.0:port,本機所有ipv4對應(yīng)的端口號
4. [::]:port,包括ipv4和ipv6
5. unix socket文件
直接配置使用unix socket文件之后,會遇到access deny的問題,由于socket文件本質(zhì)上還是一個文件,存在權(quán)限控制問題,默認由root用戶創(chuàng)建,因此nginx進程無權(quán)限訪問,應(yīng)該配置如下命令:
; Set permissions for unix socket, if one is used. In Linux, read/write ; permissions must be set in order to allow connections from a web server. Many ; BSD-derived systems allow connections regardless of permissions. ; Default Values: user and group are set as the running user ; mode is set to 0660 listen.owner = www listen.group = www listen.mode = 0660
可以配置nginx和php-fpm都是用www用戶,這樣就不會存在權(quán)限問題,當然也可以創(chuàng)建不同的用戶,然后加入同一個組,便于分配權(quán)限。
以上是“nginx與php-fpm通信的方式有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。