我已经做了几天的阅读这个问题,诚然,我是一个Nginx新手。 我已经阅读了官方和非官方的文件,似乎无法解决我的问题。 希望这里有人能够帮我一把。
我可以服务我的HTML页面,如403,404和50x.html,所以我知道nginx正在一定的能力。 我的httpsredirect也适用。
我可以telnet到9001上的PHP FPM。
我的所有权限都是正确的,至less对我来说是正确的
我在下面包含了相关的configuration文件和输出:
网站可用/默认:
server { listen [::]:80; server_name domain.com; return 301 https://domain.com$request_uri; #rewrite ^ https://domain.com$request_uri? permanent; } server { listen 443 default ssl; server_name domain.com; ssl on; ssl_certificate /etc/ss-certificates/ss-domain.com.crt; ssl_certificate_key /etc/ss-certificates/ss-domain.com.key; root /var/www/domain.com/wwwroot; index index.php; access_log /var/www/domain.com/logs/access.log combined; error_log /var/www/domain.com/logs/error.log debug; error_page 404 /404.html; error_page 403 /403.html; error_page 500 502 503 504 /50x.html; location / { try_files $uri $uri/ /index.php?q=$uri&$args; } location ~ \.php$ { try_files $uri =404; include fastcgi_params; fastcgi_param HTTPS on; 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 SCRIPT_FILENAME $document_root$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 GATEWAY_INTERFACE CGI/1.1; fastcgi_param SERVER_SOFTWARE nginx; 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; fastcgi_pass 127.0.0.1:9001; } location ~ /\.ht { deny all; } location = /favicon.ico { log_not_found off; access_log off; } }
pool.d / domain.com.conf:
[domain] listen = 127.0.0.1:9001 user = www-data group = www-data pm = dynamic pm.max_children = 10 pm.start_servers = 4 pm.min_spare_servers = 2 pm.max_spare_servers = 6 chroot = /var/www/domain.com/wwwroot/ chdir = /
网站目录:
ll -s -R /var/www/domain.com/ /var/www/domain.com/: total 16 4 drwxr-xr-x 4 www-data www-data 4096 Jul 23 22:48 ./ 4 drwxr-xr-x 3 root root 4096 Jul 22 22:49 ../ 4 drwxr-xr-x 2 www-data www-data 4096 Jul 25 22:59 logs/ 4 drwxr-xr-x 2 www-data www-data 4096 Jul 28 15:00 wwwroot/ /var/www/domain.com/logs: total 516 4 drwxr-xr-x 2 www-data www-data 4096 Jul 25 22:59 ./ 4 drwxr-xr-x 4 www-data www-data 4096 Jul 23 22:48 ../ 24 -rw-r--r-- 1 www-data www-data 18128 Jul 28 15:19 access.log 484 -rw-r--r-- 1 www-data www-data 490826 Jul 28 15:20 error.log /var/www/domain.com/wwwroot: total 28 4 drwxr-xr-x 2 www-data www-data 4096 Jul 28 15:00 ./ 4 drwxr-xr-x 4 www-data www-data 4096 Jul 23 22:48 ../ 4 -rw-r--r-- 1 www-data www-data 53 Jul 26 22:56 403.html 4 -rw-r--r-- 1 www-data www-data 53 Jul 26 22:55 404.html 4 -rw-r--r-- 1 www-data www-data 383 Jul 23 22:42 50x.html 4 -rw-r--r-- 1 www-data www-data 1406 Jul 25 21:46 favicon.ico 4 -rwxr-xr-x 1 www-data www-data 88 Jul 22 22:58 index.php*
nginx.conf:
user www-data; worker_processes 4; pid /var/run/nginx.pid; events { worker_connections 768; # multi_accept on; } http { ## # Basic Settings ## sendfile on; tcp_nopush on; tcp_nodelay on; keepalive_timeout 65; types_hash_max_size 2048; # server_tokens off; # server_names_hash_bucket_size 64; # server_name_in_redirect off; include /etc/nginx/mime.types; default_type application/octet-stream; ## # Logging Settings ## access_log /var/log/nginx/access.log; error_log /var/log/nginx/error.log; ## # Gzip Settings ## gzip on; gzip_disable "msie6"; # gzip_vary on; # gzip_proxied any; # gzip_comp_level 6; # gzip_buffers 16 8k; # gzip_http_version 1.1; # gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript; ## # nginx-naxsi config ## # Uncomment it if you installed nginx-naxsi ## #include /etc/nginx/naxsi_core.rules; ## # nginx-passenger config ## # Uncomment it if you installed nginx-passenger ## #passenger_root /usr; #passenger_ruby /usr/bin/ruby; ## # Virtual Host Configs ## include /etc/nginx/conf.d/*.conf; include /etc/nginx/sites-enabled/*; }
在此先感谢大家的帮助。
问候,
JG
您的访问/错误日志中是否有任何内容?
另外,为什么你包含fastcgi_params,然后几乎定义它们呢?
这是我的位置块在php-fpm中的nginx中的样子:
location ~ \.php$ { try_files $uri =404; fastcgi_intercept_errors on; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /path/to/site.com/public$fastcgi_script_name$ fastcgi_param PATH_INFO $fastcgi_script_name; include fastcgi_params; }
尝试将fastcgi_pass向上移动。
这里的问题是你把php-fpm放在chroot监狱里,但是nginx会把完整的SCRIPT_FILENAMEpath传递给PHP脚本。
在你的nginx conf中你有(除其他外):
root /var/www/domain.com/wwwroot; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
对于/index.php
的请求,他将翻译成/var/www/domain.com/wwwroot/index.php
。 但是你已经把php-fpm放入chroot监狱了:
chroot = /var/www/domain.com/wwwroot/
所以php-fpm在/index.php
看到这个文件,而不是/var/www/domain.com/wwwroot/index.php
。
因此,您必须调整SCRIPT_FILENAME
的path,以便它匹配php-fpm将在chroot中看到的内容。 通过剥离$document_root
做到这一点。
fastcgi_param SCRIPT_FILENAME $fastcgi_script_name;
我想你不能让nginx在浏览器中显示你的.php文件。
我看到很多你简单不需要的东西,为了让php工作。 据我所知,并已阅读,你只能通过一个“fastcgi_param”参数。 就我所知,这就是FastCGI的工作原理。 如果你有多个fastcgi_param参数,nginx会select第一个参数,尝试只列出“fastcgi_pass 127.0.0.1:9001;”作为fastcgi参数,看看会发生什么。
你可以阅读更多关于这个网页上的fastcgi http://michaelshadle.com/2011/02/11/setting-php-ini-parameters-from-nginx