api-breaker

    定义

    由代码逻辑自动按触发不健康状态的次数递增运算:

    每当上游服务返回配置中的状态码(比如:500),达到unhealthy.failures次时(比如:3 次),认为上游服务处于不健康状态。

    然后,2 秒过后重新开始转发请求到上游服务,如果继续返回unhealthy.http_statuses状态码,记数再次达到次时,熔断 4 秒(倍数方式)。

    依次类推,2, 4, 8, 16, 32, 64, …, 256, 最大到 300。 300 是 max_breaker_sec 的最大值,允许自定义修改。

    在不健康状态时,当转发请求到上游服务并返回healthy.http_statuses配置中的状态码(比如:200),达到次时(比如:3 次),认为上游服务恢复健康状态。

    启用方式

    使用上游的配置,如果你的上流服务返回 500,连续 3 次。客户端将会收到 502(break_response_code)应答。

    禁用插件

    当想禁用api-breaker插件时,非常简单,只需要在插件配置中删除相应的 json 配置,无需重启服务,即可立即生效:

    插件现在已被禁用,它也适用于其他插件。