Nginx中502错误怎么办

  介绍

小编给大家分享一下Nginx中502错误怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获、下面让我们一起去了解一下吧!

<强>详解Nginx 502错误解决办法

<强> 1。配置错误

因为Nginx找不到php-fpm了,所以报错,一般是fastcgi_pass后面的路径配置错误了,后面可以是套接字或者是ip:港口

<强> 2。资源耗尽

lnmp架构在处理php时,nginx直接调取后端的php-fpm服务,如果nginx的请求量偏高,我们又没有给php-fpm配置足够的子进程,那么php-fpm就会资源耗尽,一旦资源耗尽nginx找不到php-fpm就会出现502错误,

解决方案去调整php-fpm.conf中的pm.max_children数值,使其增加,但是也不能无限增加,毕竟资源有限,一般4 g内存机器如果跑php-fpm和nginx,不跑mysql可以设置为150年,8 g为300年以此类推

<强> 3。除了上面的两种错误还有其他的原因,很少有,我们可以借助nginx的错误日志来进行排查vim/usr/local/nginx/logs/nginx_error。日志我们也可以给日志定义级别vim/usr/地方/nginx/conf/nginx。参看找到error_log,默认是暴击最严谨的就行,也可以改成调试显示的信息最全面,但是很容易撑爆我们的磁盘

首先我们需要让浏览器进行访问修改nginx的配置文件

[root@wqslinux  ~] #, vim/usr/地方/nginx/conf/vhost/111.相依      服务器   {   listen 才能;80;   server_name 才能;www.111.com,,,,,//域名地址   index 才能index.html  index.htm  index . php。   root 才能;/数据/www/;      的位置才能~,\美元。php, {   ,,,include  fastcgi_params;   ,,,fastcgi_pass  unix:/tmp/www.sock,,//修改袜子   ,,# fastcgi_pass  127.0.0.1:9000;   ,,,fastcgi_index  index . php。   ,,,fastcgi_param  SCRIPT_FILENAME /数据/www fastcgi_script_name美元;   ,,}      }

检查语法是否正常

[root@wqslinux  ~] #/usr/地方/nginx/sbin/nginx  - t

重新加载配置文件

[root@wqslinux  ~] #,/usr/地方/nginx/sbin/nginx-s 重新加载   [root@wqslinux  ~) #,/etc/摆在nginx 重载

检查nginx是那个用户跑的

[root@wqslinux  ~] #, ps  aux  | grep  nginx

编辑php-fpm文件我们要在这个php-fpm文件里面设置nginx的用户主,跟组这样才不会显示502

[root@wqslinux  ~] #, vim/usr/地方/php/etc/php-fpm.conf      (全球)   时间=pid /usr/地方/php/var/运行/php-fpm.pid   error_log =/usr/地方/php/var/log/php-fpm.log   (www)   listen =,/tmp/www.sock   user =php-fpm   group =php-fpm   时间=listen.owner  nobody ,//定义属主   时间=listen.group  nobody ,//定义属组   时间=pm 动态   pm.max_children =50   pm.start_servers =20   时间=pm.min_spare_servers  5   pm.max_spare_servers =35   pm.max_requests =500   rlimit_files  1024=,

配置完之后重启php-fpm

[root@wqslinux  ~] #,/etc/摆在php-fpm 启动

ps:再补充一个,是近期很多同学遇到的问题这种情况下,使用的是插座,版本高于5.4(含5.4)默认监听的套接字文件权限是所有者只读,属组和其他用户没有任何权限,所以,nginx的启动用户(咱们配置的是没人)就没有办法去读这个套接字文件,最终导致502,这个问题可以在nginx的错误日志中发现。解决办法很简单,上面给出的配置文件中就有避免这个问题的配置。

listen.owner =, nobody ,//定义属主   listen.group =, nobody ,//定义属组

这两个配置就是定义插座的属主和属组是谁。除了这个还有一种方法

listen.mode =, 777

这样没人也可以有读取权限了。

以上是“Nginx中502错误怎么办”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

Nginx中502错误怎么办