php连接数据库出现502错误
nginx+php 出现502 bad gateway,一般这都不是nginx的问题,而是由于 fastcgi或者php的问题导致的,常见的有以下几种。
1. php.ini 的memory_limit 过小(如果有个别php程序进程需要占用极大内存时这个必须注意)
2. php-fpm.conf 中max_children或者max_requests 设置不合理(设置过小会因为没有足够的cgi进程处理请求,设置过大会出现一会儿有响应正常,一会儿等很久才有响应的情况,一般情况下children 按 照内存计算,比如说1G设置64,2G128。这个根据实际情况自行调整。
另外查看当前的PHP FastCGI进程数是否够用的命令为:netstat -anpo |grep “php-cgi” | wc -l 如果实际使用的“FastCGI进程数”接近预设的“FastCGI进程 数”,那么,说明“FastCGI进程数”不够用,需要增大。)
3. 查看nginx错误日志,发现 pstream sent too big header while reading response headerfrom upstream ,则检查client head buffer,fastcgi buffer size是否过小,可设置为32K。
4. php 程序执行时间过长而超时,检查nginx和fastcgi中各种timeout设置。
(nginx 中的 fastcgi_connect_timeout 300;fastcgi_send_timeout 300 :fastcgi_read_timeout300; keepalive_timeout ; php-fpm中的request_terminate_timeout,php.ini中的max_execution_time)
5. php-fpm 有一个参数 max_requests ,该参数指明了每个children最多处理多少个请求后便会被关闭。在大量处理请求下,如果该值设置过小会导致 children频繁的自杀和建立而浪费 大量时间,若所有的children差不多都在这个时候自杀,则重建前将没有children响应请求,于是出现502 。可以将该值设置大一些或者是0[无限]。
推荐:php服务器
以上就是php连接数据库出现502错误的详细内容,更多请关注其它相关文章!
上一篇: 微信小程序如何实现美团菜单
推荐阅读
-
php连接oracle数据库的核心步骤,oracle数据库
-
php已经支持Mysql,但是一连接数据库就显示无法连接?咋回事、
-
PHP连接Access数据库代码
-
Win7 64位系统下PHP连接Oracle数据库,win7oracle
-
php代码出现错误分析详解_PHP
-
php-PHPExcel中,把“= =”写入表格会出现错误,怎么解决呢?
-
PHP下使用mysqli的函数连接mysql出现warning: mysqli::real_connect: hy000/1040:
-
php 升级到 5.3+ 后出现的一些错误,如 ereg(); ereg_replace(); 函数报错_php实例
-
PHP5中使用PDO连接数据库的方法_php技巧
-
php 连接mssql数据库 初学php笔记