[英]Nginx 504 Time-out with php-fpm
我为我的一个站点收到504网关超时。 请帮忙找出原因?
这是我的nginx配置:
server {
listen 80;
server_name domain.com;
root /home/user/domain.com;
error_log /home/user/domain.com/error.log;
location / {
try_files $uri /index.php?q=$uri&$args;
}
location ~ \.php$ {
include fastcgi_params;
fastcgi_pass unix:/var/run/php5-fpm.sock;
fastcgi_split_path_info ^(.+\.php)(/.*)$;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}
}
Nginx错误日志:
$ sudo tail -n 1 domain.com/error.log
2014/08/21 17:09:35 [error] 16790#0: *30 upstream timed out (110: Connection timed out) while reading response header from upstream, client: 5.18.54.52, server: domain.com, request: "GET / HTTP/1.1", upstream: "fastcgi://unix:/var/run/php5-fpm.sock", host: "domain.com"
而且在php-fpm日志中什么也没有:
sudo tail -n 1 /var/log/php5-fpm.log
[21-Aug-2014 17:08:31] NOTICE: ready to handle connections
这是我的www.conf:
$ sudo nano /etc/php5/fpm/pool.d/www.conf
pm = dynamic
pm.max_children = 50
pm.start_servers = 5
pm.min_spare_servers = 1
pm.max_spare_servers = 10
请帮我解决这个问题! 谢谢!
从PHP 5.5.12开始,更改了FPM套接字权限以解决与安全相关的错误,您可以在此处详细了解-> https://bugs.php.net/bug.php?id=67060
现在,您的FPM池配置中的listen.mode = 0660
应该设置为listen.mode = 0666
。 还要确保您的listen.owner
和listen.group
是运行Nginx的相同用户名/组。 这是我设置中的内容:
listen.owner = nginx
listen.group = nginx
listen.mode = 0666
我假设您的Nginx配置具有user www-data;
然后只需将我上面的nginx
参考更改为www-data
。
至于Nginx,这是我当前正在使用的工作示例:
# PHP-FPM Support
location ~ \.php$ {
fastcgi_pass unix:/var/run/nginx.sock;
include fastcgi.conf;
}
我认为您的Nginx配置很好,但是如果您想尝试一些不同的东西,我会发布配置作为对您的测试。
在进行任何配置更改后,请不要忘记重新启动PHP-FPM。
试试看,我确定它可以解决您的问题。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.