当前位置: 首页 > news >正文

istio如何自定义重试状态码

HTTP 4xx 状态码表示客户端错误,意味着请求有问题(例如,格式错误、未授权、资源不存在等)。以下是常见的 4xx 状态码列表,整理为 Markdown 格式:

4xx 状态码列表

  • 400 Bad Request:请求格式错误或无效(例如,参数缺失、格式不正确)。
  • 401 Unauthorized:客户端未提供有效认证凭证(需登录或提供 token)。
  • 402 Payment Required:保留状态码,当前少用,可能用于要求支付。
  • 403 Forbidden:客户端无权限访问资源(认证通过但无访问权限)。
  • 404 Not Found:请求的资源在服务器上不存在。
  • 405 Method Not Allowed:请求的 HTTP 方法(如 GET、POST)不被资源支持。
  • 406 Not Acceptable:服务器无法提供客户端请求的格式(基于 Accept 头)。
  • 407 Proxy Authentication Required:需要代理服务器认证。
  • 408 Request Timeout:客户端请求超时,服务器未在规定时间内收到完整请求。
  • 409 Conflict:请求与服务器资源状态冲突(如并发修改、版本不匹配)。
  • 410 Gone:资源已永久删除,且无转发地址。
  • 411 Length Required:请求缺少 Content-Length 头。
  • 412 Precondition Failed:请求的先决条件(基于 If-Match 等头)未满足。
  • 413 Payload Too Large:请求体过大,服务器拒绝处理。
  • 414 URI Too Long:请求的 URI 过长,服务器无法处理。
  • 415 Unsupported Media Type:请求的媒体类型(如 Content-Type)不被支持。
  • 416 Range Not Satisfiable:请求的范围(Range 头)无效或无法满足。
  • 417 Expectation Failed:服务器无法满足 Expect 请求头的要求。
  • 418 I’m a teapot:愚人节玩笑状态码(RFC 2324),实际不常用。
  • 422 Unprocessable Entity:请求格式正确但语义错误(常用于 WebDAV 或 API)。
  • 423 Locked:资源被锁定(常用于 WebDAV)。
  • 424 Failed Dependency:请求依赖的其他操作失败(WebDAV)。
  • 426 Upgrade Required:客户端需升级协议(如切换到 TLS/1.0)。
  • 428 Precondition Required:请求缺少必要的先决条件(如 If-Match)。
  • 429 Too Many Requests:客户端请求频率超限(限流场景)。
  • 431 Request Header Fields Too Large:请求头字段过大,服务器拒绝处理。
  • 451 Unavailable For Legal Reasons:因法律原因(如审查)无法访问资源。

在 Istio 中的 4xx 重试

结合你之前的问题,以下是关于 4xx 状态码在 Istio 重试上下文中的说明:

  • 默认不可重试:Istio 默认不将任何 4xx 状态码视为可重试,因为它们通常表示客户端错误,重试可能无效。
  • 潜在可重试的 4xx 状态码
    • 429 Too Many Requests:限流场景,结合 Retry-After 头延迟重试可能有效。
    • 401 Unauthorized:如果客户端能动态刷新凭证(如 token),可考虑重试。
    • 408 Request Timeout:可能由临时网络问题引起,适合重试。
    • 409 Conflict:在特定场景(如临时分布式锁冲突)可重试,但需谨慎。
  • 配置方法:通过 EnvoyFilter 设置 retriable_status_codes
    apiVersion: networking.istio.io/v1alpha3
    kind: EnvoyFilter
    metadata:name: retriable-4xxnamespace: istio-system
    spec:configPatches:- applyTo: HTTP_ROUTEmatch:context: SIDECAR_OUTBOUNDpatch:operation: MERGEvalue:route:retry_policy:retry_on: "retriable-status-codes"retriable_status_codes:- 401- 408- 409- 429num_retries: 3per_try_timeout: 2s
    

注意事项

  • 4xx 重试谨慎:大部分 4xx 状态码(如 400、403、404)重试无意义,可能增加无效请求。
  • 409 特殊性:如前所述,409 表示冲突,通常需客户端处理(如更新版本号)后重试,而非盲目重试。
  • 429 限流:重试 429 需结合延迟策略(如 Retry-After 头),否则可能加剧限流。
  • Istio 限制:当前版本(截至 1.10.2)不支持通过 VirtualService 直接设置 retriable-4xx 或基于响应头的重试,需用 EnvoyFilter

总结

  • 4xx 状态码:涵盖 400-451,常见如 400、401、403、404、409、429 等。
  • Istio 重试:默认不重试 4xx,可通过 EnvoyFilter 配置 401、408、409、429 等为可重试。
  • 推荐:仅在明确业务场景(如 429 限流、401 凭证刷新)下配置 4xx 重试,并确保与应用程序逻辑协调。
http://www.dtcms.com/a/284119.html

相关文章:

  • JAVA面试宝典 -《缓存架构:穿透 / 雪崩 / 击穿解决方案》
  • JVM 内存分配与垃圾回收策略
  • Java学习--JVM(2)
  • Java面试(基础篇) - 第二篇!
  • 如何用 Python + LLM 构建一个智能栗子表格提取工具?
  • Spring,Spring Boot 和 Spring MVC 的关系以及区别
  • 深入解析Hadoop:机架感知算法与数据放置策略
  • #Linux内存管理# vm_normal_page()函数返回的什么样页面的struct page数据结构?为什么内存管理代码中需要这个函数?
  • 【机器学习】第三章 分类算法
  • 如何判断你的EDA工具安装是否真的成功?
  • 数据呈现:让图表说话,从数字到洞察的可视化艺术
  • “显著性”(Saliency)是计算机视觉中的一个重要概念,主要指的是图像或视频中最吸引人注意力的区域或对象
  • Python进阶操作——创建容器
  • Ubuntu开启root用户登陆
  • MyBatis延迟加载(Lazy Loading)之“关联查询”深度解析与实践
  • ros0基础-day13
  • java之json转excel生成
  • Oracle11.2.0.4 RAC迁移升级Oracle19.3 RAC
  • R语言基础| 基本图形绘制(条形图、堆积图、分组图、填充条形图、均值条形图)
  • 规则引擎rule-engine(三)可视化api设计和实现解释
  • 解读一个大学专业——信号与图像处理
  • 2025年Java后端秋招面试的高频八股文+场景题
  • NFS、iSCSI 和lnmp部署操作
  • 深度学习之神经网络(二)
  • 神经网络常见激活函数 15-B-SiLU 函数
  • OCR 赋能档案数字化:让沉睡的档案 “活” 起来
  • 无线充电技术详解:原理、芯片选型与应用场景
  • Android开发中Retrofit使用方法与底层原理详解
  • 学习设计模式《十八》——备忘录模式
  • 第5天 | openGauss中一个用户可以访问多个数据库