zoukankan      html  css  js  c++  java
  • Nginx 504响应超时

    1.问题分析

    nginx访问出现504 Gateway Time-out,一般是由于程序执行时间过长导致响应超时,例如程序需要执行90秒,而nginx最大响应等待时间为30秒,这样就会出现超时。 
      
    通常有以下几种情况导致

    1.程序在处理大量数据,导致等待超时。 
    2.程序中调用外部请求,而外部请求响应超时。 
    3.连接数据库失败而没有停止,死循环重新连。

    出现这种情况,我们可以先优化程序,缩短执行时间。另一方面,可以调大nginx超时限制的参数,使程序可以正常执行。

    对于访问超时的设定,nginx与php都有相关的设置,可以逐一进行修改。

    2.解决方法

    nginx配置

    nginx.conf中,设置以下几个参数,增加超时时间

    fastcgi_connect_timeout 
    fastcgi连接超时时间,默认60秒

    fastcgi_send_timeout 
    nginx 进程向 fastcgi 进程发送请求过程的超时时间,默认值60秒

    fastcgi_read_timeout 
    fastcgi 进程向 nginx 进程发送输出过程的超时时间,默认值60秒


    php配置

    php.ini

    max_execution_time 
    php脚本最大执行时间 
      
    php-fpm

    request_terminate_timeout 
    设置单个请求的超时时间

      
    php程序中可加入set_time_limit(seconds)设置最长执行时间

    例如 set_time_limit(0) 表示不超时。
     

  • 相关阅读:
    zabbix 主被动模式
    MySQL角色(role)功能介绍
    MySQL权限管理实战
    创建索引,这些知识应该了解
    MySQL锁等待与死锁问题分析
    Navicat操作MySQL简易教程
    职场里,对数据库要有敬畏之心!
    MySQL字段默认值设置详解
    MySQL查看及杀掉链接方法大全
    MySQL字段类型最全解析
  • 原文地址:https://www.cnblogs.com/peteremperor/p/11137242.html
Copyright © 2011-2022 走看看