nginx下部署php專案的方法:1、安裝完畢nginx和php-fpm;2、找到nginx伺服器的組態檔;3、指定php專案的部署位置;4、把設定好的各種server conf放在sites-enabled裡即可。
本文操作環境:linux5.9.8系統、nginx1.9版、Dell G3電腦。
nginx下怎麼部署php專案?
nginx伺服器上部署php專案
nginx本身不能處理PHP頁面,它只是個web伺服器,當接收到請求後,如果是PHP請求,通過反向代理的方式轉發給PHP直譯器處理,並把結果返回給使用者端。因此需要在伺服器上安裝nginx和php-fpm或其他php直譯器。
安裝完畢nginx和php-fpm後,找到nginx伺服器的組態檔
[root@test24266conf]# ps -ef | grep nginx.conf root 31441 1 0 2018 ? 00:00:00 nginx: master process /usr/local/nginx/sbin/nginx -c/usr/local/nginx/conf/nginx.conf
在這個檔案中,指定php專案的部署位置,即修改server欄位下root 指定的檔案根目錄。
很多髮型版本,在nginx.conf並沒有server欄位,這是為了管理方便,某些發行版的預編譯版本里,nginx.conf 中 http 段最後會有兩句 include conf.d/*.conf; include sites-enabled/*或只有一條include
sites-enabled/*.conf; 這樣你就可以把已經設定好的各種 server conf 放在sites-enabled 裡,如
[root@test24266conf]# ll sites-enabled/ -rw-r--r--1 root root 603 103 2017 captcha443.conf -rw-r--r--1 root root 287 9 1 2017 commrisk.conf -rw-r--r--1 root root 194 129 2016 imagerotate.conf -rw-r--r--1 root root 402 9 2 2016 msgqapi.conf -rw-r--r--1 root root 295 102 2017 pointriskapi.conf -rw-r--r--1 root root 290 6 2 2017 risktrade.conf -rw-r--r--1 root root 309 814 2017 rotateapi.conf -rw-r--r--1 root root 313 100 2016 watchdog.conf [root@test24266conf]# 這樣每個.conf檔案就可以對應一個虛擬主機,檢視某個組態檔,如 [root@test24266conf]# cat sites-enabled/pointriskapi.conf server{ listen 8013; server_name point.risk.api; index index.php; #預設存取的檔案 root /var/www/pointriskapi/hosts; access_log on;
#當請求網站下php檔案的時候,反向代理到php-fpm location ~ .*\.php?$ { include fastcgi.conf; } location = /favicon.ico { log_not_found off; access_log off; } } [root@test24266conf]#
我們將php專案檔案放入這個/var/www/pointriskapi/hosts路徑下,如
[root@test24266hosts]# ll -rw-r--r-- 1 apache apache 339 102 2017risk_point.php [root@test24266hosts]# pwd /var/www/pointriskapi/hosts
一般不需要重新啟動Nginx和php-fpm。現在在使用者端就可以存取http://ip:8013/risk_point.php了。
那麼nginx是怎麼通過反向代理的方式將請求轉發給PHP直譯器呢?我們注意到server欄位中有一段
location ~ .*\.php?$ { include fastcgi.conf; #載入nginx的fastcgi模組 }
該段指明瞭.php檔案由誰處理。我們檢視nginx.conf同級目錄下的factcgi.conf檔案,如
[root@test24266 conf]# cat fastcgi.conf fastcgi_pass 127.0.0.1:9000; #fastcgi_pass unix:/tmp/phpcgi.socket; fastcgi_indexindex.php; access_log /var/log/httpd/access_log main; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param QUERY_STRING $query_string; fastcgi_param REQUEST_METHOD $request_method; fastcgi_param CONTENT_TYPE $content_type; fastcgi_param CONTENT_LENGTH $content_length; fastcgi_param SCRIPT_NAME $fastcgi_script_name; fastcgi_param REQUEST_URI $request_uri; fastcgi_param DOCUMENT_URI $document_uri; fastcgi_param DOCUMENT_ROOT $document_root; fastcgi_param SERVER_PROTOCOL $server_protocol; fastcgi_param HTTPS $https if_not_empty; fastcgi_param GATEWAY_INTERFACE CGI/1.1; fastcgi_param SERVER_SOFTWARE nginx/$nginx_version; fastcgi_param REMOTE_ADDR $remote_addr; fastcgi_param REMOTE_PORT $remote_port; fastcgi_param SERVER_ADDR $server_addr; fastcgi_param SERVER_PORT $server_port; fastcgi_param SERVER_NAME $server_name; # PHPonly, required if PHP was built with --enable-force-cgi-redirect fastcgi_param REDIRECT_STATUS 200; [root@test24266conf]#
Fastcgi_pass指明瞭fastcgi程序監聽的IP地址和埠,即nginx會將請求轉發給這個socket。因此我們需要在php-fpm的組態檔中指明同樣的socket。啟動Php-fpm監聽,檢視
[root@test24266~]# netstat -anp | grep 9000 tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN 3719/php-fpm
總結一下在nginx與php-fpm模式下,完整的請求和應答流程是這樣的:
1、使用者端請求伺服器上某個.php檔案
2、Nginx發現是動態資源需要路由到指定根目錄下
3、載入nginx的fast-cgi模組
4、Fact-cgi監聽127.0.0.1:9000(預設socket)
5、php-fpm接收到請求,啟用worker程序處理請求
6、php-fpm處理完請求,返回給nginx
7、nginx將結果通過http返回給瀏覽器
推薦學習:《》
以上就是nginx下怎麼部署php專案的詳細內容,更多請關注TW511.COM其它相關文章!