Nginx请求upstream timed out 错误时通常会尝试重新请求上游服务器(504 Gateway Timeout)

重新记录一下这个重复的nginx请求的问题:

背景

一个导出报表任务,下载报表时,发生了导出超时:504 Gateway Timeout的错误。

504 Gateway Timeout的原因如下

  1. Nginx配置问题:检查您的Nginx配置是否正确。确保Nginx已经正确地重新加载了新的配置。您可以使用nginx -t命令来测试Nginx配置文件的语法是否正确,然后使用nginx -s reload重新加载配置。
  2. Nginx日志:查看Nginx的访问日志和错误日志,以了解请求是否到达Nginx服务器,以及Nginx服务器是否有任何错误。这些日志通常位于/var/log/nginx/目录下。
  3. 上游服务器响应缓慢:如果Nginx的上游服务器(例如您的应用程序服务器)响应缓慢或者无响应,也会导致504错误。您可以通过直接访问上游服务器来测试它是否正常工作。
  4. 网络问题:网络问题也可能导致504错误。确保网络连接畅通,没有防火墙或者代理服务器的限制。
  5. 资源不足:如果上游服务器资源不足,也可能导致504错误。您需要检查上游服务器的资源利用情况,确保它有足够的资源来处理请求。

原因

而我发生这个错误,是因为上游服务器响应多次超时导致的。 因为 Nginx 在遇到 upstream timed out 错误时通常会尝试重新发送请求,也就是会重放原先的请求到上游服务器。

Nginx 有一些相关的配置选项可以用来控制重试行为,其中包括:

  • proxy_connect_timeout:用于设置连接超时时间,即 Nginx 等待与上游服务器建立连接的最长时间。
  • proxy_send_timeout:用于设置向上游服务器发送请求的超时时间。
  • proxy_read_timeout:用于设置从上游服务器读取响应的超时时间。
  • proxy_next_upstream:用于设置出现错误时 Nginx 应该尝试下一个上游服务器的策略。

您可以在 Nginx 配置文件中设置这些选项,以便根据您的需求来调整 Nginx 对上游服务器的请求超时和重试行为。

例如,以下是一个简单的配置示例:

location / {
    proxy_pass http://backend;
    proxy_connect_timeout 5s;
    proxy_send_timeout 10s;
    proxy_read_timeout 20s;
    proxy_next_upstream error timeout;
}

如果你没有设置这些配置值的话,Nginx的默认超时配置值可以根据不同的版本和发行版而有所不同。以下是一些常见的默认超时配置值:

  • proxy_connect_timeout:默认为60秒。
  • proxy_send_timeout:默认为60秒。
  • proxy_read_timeout:默认为60秒。

解决

对接口直接加缓存,就可以避免第二次重放请求时,覆盖了第一次的请求所写的文件。

最近更新

  1. 写一个字符设备的驱动步骤

    2024-04-03 03:16:02       0 阅读
  2. Transformer和Bert的原理是什么

    2024-04-03 03:16:02       0 阅读
  3. 使用tkinter 制作工作流ui

    2024-04-03 03:16:02       1 阅读
  4. postman工具介绍

    2024-04-03 03:16:02       1 阅读
  5. vue-路由自动化

    2024-04-03 03:16:02       1 阅读
  6. el-date-picker 扩展

    2024-04-03 03:16:02       1 阅读
  7. Go语言入门之变量、常量、指针以及数据类型

    2024-04-03 03:16:02       1 阅读
  8. Kotlin 处理livedata数据倒灌

    2024-04-03 03:16:02       1 阅读

热门阅读

  1. C++经典面试题目(十九)

    2024-04-03 03:16:02       16 阅读
  2. mysql表列中字符串逗号分割转列

    2024-04-03 03:16:02       24 阅读
  3. 音视频处理相关基础概念

    2024-04-03 03:16:02       15 阅读
  4. 关于Qt的安装与版本更换

    2024-04-03 03:16:02       20 阅读
  5. 面试题:Spring RESTful服务设计与控制器最佳实践

    2024-04-03 03:16:02       15 阅读
  6. C# 委托与事件 终章

    2024-04-03 03:16:02       22 阅读
  7. TypeScript-数组、函数类型

    2024-04-03 03:16:02       14 阅读
  8. 动态规划详解

    2024-04-03 03:16:02       15 阅读
  9. Qt线程之QtConcurrent的介绍

    2024-04-03 03:16:02       18 阅读
  10. liblzma/xz漏洞

    2024-04-03 03:16:02       16 阅读
  11. 模板方法模式

    2024-04-03 03:16:02       14 阅读
  12. 我的创作纪念日

    2024-04-03 03:16:02       15 阅读