Apisix自定义httpcode 请求重试

我们通过插件来做比较麻烦并且还需要考虑重新lb的问题,有一个比较简单的方法是利用nginx的请求重试信号。

Apisix本身默认也有该种设定,不过默认只针对 timeout情况会请求重试

默认请求重试次数是:updateam node 节点数量 -1

相关逻辑在apisix-balancer.luaset_balancer_opts 方法中

设置Nginx配置文件,添加请求重试判断:

我们在 ngx_tpl.lua 760行添加如下配置,示例httpcode可更换
proxy_next_upstream error timeout http_500 http_429 non_idempotent;

支持重试的httpcode可以查看 nginx官方proxy-next-upstream文档

apisix在发生请求重试时,打印的日志中 upstream-statusupstream 会依次将每次请求的结果、上游地址记录出来

相关推荐
小天源5 小时前
nginx在centos7上热升级步骤
linux·服务器·nginx
小王不爱笑13214 小时前
Postman 使用教程
测试工具·lua·postman
XRJ040618xrj15 小时前
Nginx下构建PC站点
服务器·前端·nginx
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.16 小时前
Nginx 平滑升级与回滚超详细指南
运维·nginx
Exquisite.2 天前
Nginx
服务器·前端·nginx
Exquisite.2 天前
企业高性能web服务器---Nginx(2)
服务器·前端·nginx
啟明起鸣2 天前
【Nginx 网关开发】从源码分析 Nginx 的多进程启动原理
运维·nginx
啟明起鸣2 天前
【Nginx 网关开发】上手 Nginx,简简单单启动一个静态 html 页面
运维·c语言·前端·nginx·html
MACKEI2 天前
服务器流式传输接口问题排查与解决方案
python·nginx·流式
TracyCoder1232 天前
Redis 进阶之路:探秘事务、Lua 与特殊数据结构
数据结构·redis·lua