当前位置:  开发笔记 > 后端 > 正文

AWS Elastic Beanstalk 504网关超时

如何解决《AWSElasticBeanstalk504网关超时》经验,为你挑选了1个好方法。

我在AWS Elastic Beanstalk上运行了一个Node服务器.我的一个端点接受巨大的有效负载,功能本身非常慢且冗长,并且可能需要超过10分钟.

由于业务需求,它必须保留为单个HTTP POST,并且不能拆分为任何小的.

在较大的通话中,我获得了504 GATEWAY TIMEOUT,总是在60秒左右.我尝试使用Elastic Beanstalk Load Balancer部分中的超时设置无效,似乎最长的超时持续时间是60秒.

我确实在https://docs.aws.amazon.com/elasticloadbalancing/latest/classic/config-idle-timeout.html上的文档中看到了一个有希望的解决方案

要确保文件上载等冗长的操作有时间完成,请在每个空闲超时时间过去之前发送至少1个字节的数据

这听起来就像我需要的,但我不知道如何完成

1)如何从我的节点应用程序"发送至少1个字节的数据"以确保会话保持活动并且在一分钟后不会超时



1> asaf am..:

可以通过设置ELB策略来解决ElasticBeanstalk环境上的504超时问题.可能还需要更新Nginx超时配置.

ELB策略:将Elastic Load Balancer的空闲超时设置为您选择的值(默认为60秒).为此,请在项目的根目录中创建.ebextensions文件夹.在此文件夹中创建另一个带有.config文件扩展名的文件,并将ELB空闲超时设置为您选择的值(例如300秒):

option_settings:
  - namespace: aws:elb:policies
    option_name: ConnectionSettingIdleTimeout
    value: 300

或者,如果您使用的是应用程序负载均衡器:

option_settings:
  - namespace: aws:elbv2:loadbalancer
    option_name: IdleTimeout
    value: 300

nginx的配置:设置Nginx的所述带超时的所需的值:send_timeout,proxy_connect_timeout,proxy_read_timeout, proxy_Send_timeout所有默认至60(附加规范,以检查可能是:client_header_timeout,client_body_timeout,keepalive_timeout).Nginx中的默认超时值在规范和配置文件中指定(例如,下面的.config文件/etc/nginx).在.ebextensions文件夹中创建一个新文件(或在上面的.config文件中更新),并在文件中追加以下内容(根据观察到的超时添加或删除相关设置):

files:
  "/etc/nginx/conf.d/nginx.custom.conf":
      mode: "644"
      owner: "root"
      group: "root"
      content: |
        client_header_timeout   300;
        client_body_timeout     300;
        keepalive_timeout       300;
        send_timeout            300;
        proxy_connect_timeout   300;
        proxy_read_timeout      300;
        proxy_send_timeout      300;

container_commands:
  01_restart_nginx:
    command: "sudo service nginx reload"

还有几种方法可以添加此配置.在这里和这里阅读更多.

推荐阅读
雯颜哥_135
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有