Nginx哀求upstream timed out 错误时通常会尝试重新哀求上游服务器(504 Ga ...

王柳  金牌会员 | 2024-8-12 20:10:47 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 539|帖子 539|积分 1617

重新记录一下这个重复的nginx哀求的题目:
背景

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

  • Nginx设置题目:检查您的Nginx设置是否精确。确保Nginx已经精确地重新加载了新的设置。您可以使用nginx -t下令来测试Nginx设置文件的语法是否精确,然后使用nginx -s reload重新加载设置。
  • Nginx日记:查看Nginx的访问日记和错误日记,以相识哀求是否到达Nginx服务器,以及Nginx服务器是否有任何错误。这些日记通常位于/var/log/nginx/目录下。
  • 上游服务器相应迟钝:假如Nginx的上游服务器(比方您的应用程序服务器)相应迟钝或者无相应,也会导致504错误。您可以通过直接访问上游服务器来测试它是否正常工作。
  • 网络题目:网络题目也可能导致504错误。确保网络毗连流通,没有防火墙或者署理服务器的限制。
  • 资源不足:假如上游服务器资源不足,也可能导致504错误。您需要检查上游服务器的资源利用情况,确保它有足够的资源来处理哀求。
缘故因由

而我发生这个错误,是因为上游服务器相应多次超时导致的。 因为 Nginx 在遇到 upstream timed out 错误时通常会尝试重新发送哀求,也就是会重放原先的哀求到上游服务器。
Nginx 有一些相关的设置选项可以用来控制重试举动,其中包括:


  • proxy_connect_timeout:用于设置毗连超时时间,即 Nginx 等候与上游服务器建立毗连的最长时间。
  • proxy_send_timeout:用于设置向上游服务器发送哀求的超时时间。
  • proxy_read_timeout:用于设置从上游服务器读取相应的超时时间。
  • proxy_next_upstream:用于设置出现错误时 Nginx 应该尝试下一个上游服务器的策略。
您可以在 Nginx 设置文件中设置这些选项,以便根据您的需求来调整 Nginx 对上游服务器的哀求超时和重试举动。
比方,以下是一个简朴的设置示例:
  1. location / {
  2.     proxy_pass http://backend;
  3.     proxy_connect_timeout 5s;
  4.     proxy_send_timeout 10s;
  5.     proxy_read_timeout 20s;
  6.     proxy_next_upstream error timeout;
  7. }
复制代码
假如你没有设置这些设置值的话,Nginx的默认超时设置值可以根据不同的版本和发行版而有所不同。以下是一些常见的默认超时设置值:


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

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

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

王柳

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表