摘要:找不到文件問(wèn)題的站點(diǎn)配置文件段要這樣路徑配置必須要有,而且必須要寫對(duì)別笑,真的能寫錯(cuò)用,而不是具體路徑權(quán)限問(wèn)題也是坑最多的。本例,之上的每一層目錄都有,所以可以訪問(wèn)到目錄。測(cè)試方法網(wǎng)頁(yè)文件的上下文,如果更換目錄需要配上。
相信很多配置php環(huán)境的都遇到過(guò)這個(gè)惱人的問(wèn)題:
瀏覽器訪問(wèn)php文件,返回來(lái) File not found
查看/var/log/nginx/error.log ,有 “Primary script unknown”,類似如下:
2019/01/03 10:24:02 [error] 11931#11931: *260 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream, client: 1.2.3.4, server: localhost, request: "GET /index.php HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000", host: "www.example.com"
原因只有兩個(gè),一個(gè)是php-fpm找不到php文件,一個(gè)是php-fpm沒(méi)有權(quán)限讀取和執(zhí)行文件。
1. 找不到文件問(wèn)題nginx 的站點(diǎn)配置文件php段要這樣:
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 location ~ .php$ { #root 路徑配置必須要有,而且必須要寫對(duì)(別笑,真的能寫錯(cuò)) root /usr/share/nginx/html; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; #SCRIPT_FILENAME用$document_root,而不是具體路徑 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; }2. 權(quán)限問(wèn)題
也是坑最多的。
1) 進(jìn)程用戶nginx.conf 里的 user 配置要跟 php-fpm.d/www.conf 一致,比如都用 nginx,或者自定義用戶 phpuser(再來(lái)句廢話,這個(gè)用戶需要提前建好)。
nginx.conf :
user phpuser; worker_processes auto;
php-fpm.d/www.conf :
; Unix user/group of processes ; Note: The user is mandatory. If the group is not set, the default user"s group ; will be used. user = phpuser group = phpuser
nginx 和 php-fpm 進(jìn)程/監(jiān)聽(tīng)信息:
root 19107 0.0 0.1 207644 5852 ? Ss 1月02 0:03 php-fpm: master process (/usr/local/etc/php-fpm.conf) phpuser 19108 0.0 0.1 207644 7108 ? S 1月02 0:00 php-fpm: pool www phpuser 19109 0.0 0.1 207644 7112 ? S 1月02 0:00 php-fpm: pool www root 24676 0.0 0.0 56660 1024 ? Ss 13:08 0:00 nginx: master process /usr/sbin/nginx -c /etc/nginx/nginx.conf phpuser 24677 0.0 0.7 84680 29976 ? S 13:08 0:00 nginx: worker process phpuser 24678 0.0 0.7 84324 29236 ? S 13:08 0:00 nginx: worker process tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN 19107/php-fpm: mast tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 24676/nginx: master tcp6 0 0 :::80 :::* LISTEN 24676/nginx: master
如果修改了 nginx 運(yùn)行用戶還必須要改些目錄權(quán)限:
chown -R phpuser:phpuser /var/log/nginx chown -R phpuser:phpuser /var/cache/nginx chown -R phpuser:phpuser /usr/share/nginx/html
還有l(wèi)ogrotate.d/nginx,create 640 nginx adm 這行要改:
create 640 phpuser adm2) 目錄和文件權(quán)限
php文件不必非得設(shè)為 777,讓人怪擔(dān)心的,只要是nginx和php-fpm運(yùn)行用戶可讀寫執(zhí)行即可,一般可以770 。
php文件目錄和文件樣例:
drwxrwx--- 6 phpuser phpuser 4.0K 2019-01-03 13:09 /usr/share/nginx/html -rwxrwx--- 1 phpuser phpuser 40 2019-01-03 13:09 /usr/share/nginx/html/phpinfo.php
這里有個(gè)深坑,對(duì)于使用其他目錄放置php文件的很可能中招,就是 /path/to/phpfiles 的每一層目錄都要允許 phpuser 訪問(wèn),缺一層就會(huì) Permission denied。
本例,/usr/share/nginx/html 之上的每一層目錄都有 o+rx,所以 phpuser 可以訪問(wèn)到 html 目錄。
drwxr-xr-x. 13 root root 155 2018-07-10 15:42 /usr drwxr-xr-x. 86 root root 4.0K 2018-12-17 07:33 /usr/share/ drwxr-xr-x 4 root root 40 2018-12-17 08:06 /usr/share/nginx/ drwxrwx--- 6 phpuser phpuser 4.0K 2019-01-03 13:11 /usr/share/nginx/html/
測(cè)試方法:
sudo -u phpuser ls -l /usr/share/nginx/html/3) SELINUX
nginx/apache 網(wǎng)頁(yè)文件的 selinux 上下文,如果更換目錄需要配上。(在Cenots7+php7.3上測(cè)試,沒(méi)有 selinux 上下文時(shí),靜態(tài)文件404,而php文件反倒沒(méi)有遇到問(wèn)題,沒(méi)有深究)
# ll -dZ /usr/share/nginx/html drwxr-xr-x. root root system_u:object_r:httpd_sys_content_t:s0 /usr/share/nginx/html
配置 selinux 上下文:
chcon -R -t httpd_sys_content_t /path/to/phpfiles
或者干脆關(guān)閉selinux(需要重啟服務(wù)器)
/etc/selinux/config :
SELINUX=disabled3. 最后
echo "Good Luck :)
" > /usr/share/nginx/html/phpinfo.php
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/40294.html
摘要:找不到文件問(wèn)題的站點(diǎn)配置文件段要這樣路徑配置必須要有,而且必須要寫對(duì)別笑,真的能寫錯(cuò)用,而不是具體路徑權(quán)限問(wèn)題也是坑最多的。本例,之上的每一層目錄都有,所以可以訪問(wèn)到目錄。測(cè)試方法網(wǎng)頁(yè)文件的上下文,如果更換目錄需要配上。 相信很多配置php環(huán)境的都遇到過(guò)這個(gè)惱人的問(wèn)題: 瀏覽器訪問(wèn)php文件,返回來(lái) File not found 查看/var/log/nginx/error.log ...
摘要:報(bào)錯(cuò)在的中遭到定義腳本文件的地方修改成如下方式代表當(dāng)前請(qǐng)求在指令中指定的值上面配置中的就是針對(duì)目錄下的文件進(jìn)行解析。 報(bào)錯(cuò): [error] 12691#0: *6 FastCGI sent in stderr: Primary script unknown while reading response header from upstream, client: 192.168.168...
摘要:昨天晚上忘記對(duì)開(kāi)發(fā)環(huán)境做了什么改動(dòng),導(dǎo)致今天來(lái)了在進(jìn)行接口調(diào)試的時(shí)候提示這個(gè)大多數(shù)情況下來(lái)說(shuō)是一個(gè)很簡(jiǎn)單的問(wèn)題配置里面的錯(cuò)誤。然而我檢查了我的配置,發(fā)現(xiàn)并沒(méi)有什么問(wèn)題。 昨天晚上忘記對(duì)開(kāi)發(fā)環(huán)境做了什么改動(dòng),導(dǎo)致今天來(lái)了在進(jìn)行接口調(diào)試的時(shí)候nginx提示Primary script unknown,這個(gè)大多數(shù)情況下來(lái)說(shuō)是一個(gè)很簡(jiǎn)單的問(wèn)題:nginx配置里面的script_filename...
閱讀 2212·2021-11-25 09:43
閱讀 1177·2021-11-23 09:51
閱讀 3511·2021-11-23 09:51
閱讀 3637·2021-11-22 09:34
閱讀 1573·2021-10-09 09:43
閱讀 2134·2019-08-30 15:53
閱讀 3171·2019-08-30 14:07
閱讀 579·2019-08-28 18:14