- https://apisix.apache.org/zh/docs/apisix/plugins/fault-injection/
- https://github.com/apache/apisix/issues/9203
这个插件就是做异常返回的事的,不要使用traffic-split来做这种事
核心参数
- abort.vars 执行故障注入的规则,当规则匹配通过后才会执行故障注。vars 是一个表达式的列表,来自 lua-resty-expr。
注意:
- 从原码中可以看到,fault-injection插件的优先级非常高,是11000,所以,当你使用这个插件时,如果发现配置未生效,可以修改在使用时重新配置它的优先级即可。
- fault-injection插件中的vars条件可能依赖于其它插件处理的结果,所以需要降低fault-injection的优先级。
实例如下
- 请求参数中name为jack的,直接返回403
- 请求头中,age为18的,直接返回403
- "fault-injection": {
- "_meta": {
- "disable": false,
- "priority": 1
- },
- "abort": {
- "http_status": 403,
- "body": "Fault Injection!\n",
- "vars": [
- [
- [ "arg_name","==","jack" ]
- ]
- ]
- },
- "delay": {
- "duration": 2,
- "vars": [
- [
- [ "http_age","==","18" ]
- ]
- ]
- }
- }
-
复制代码 lua-resty-expr 语法介绍
lua-resty-expr 是 OpenResty 中的一个库,用于构建复杂的条件表达式,常用于流量路由、访问控制等场景。它提供了一种声明式的 DSL 来描述条件逻辑。
基本语法结构
lua-resty-expr 的基本表达式是一个 Lua 表(table),由操作符和操作数组成:- local expr = require "resty.expr"
- local ex = expr.new({
- {op, var, val},
- {op, var, val},
- -- 更多条件...
- })
复制代码 操作符 (op)
支持的操作符包括:
<ul>比较操作符:
<ul>"==":等于
"~=":不等于
">":大于
">=":大于等于
"=", "arg_age", 18}}, {{"==", "arg_country", "US"}} } }, { {"in", "arg_role", {"admin", "superuser"}} } }})[/code]字符串操作
- local ex = expr.new({
- {"==", "arg_foo", "bar"}, -- GET 参数 foo 等于 "bar"
- {"==", "http_x_api_key", "12345"}, -- X-API-Key 头等于 "12345"
- })
复制代码 使用表达式
创建表达式对象后,可以这样使用:- local ex = expr.new({
- {"and",
- {{"==", "arg_debug", "true"}},
- {{"==", "http_user_agent", "test_client"}}
- }
- })
复制代码 注意事项
- 表达式在内部会被编译为高效的 Lua 代码
- 支持短路求值(short-circuit evaluation)
- 变量名中的 - 会被替换为 _(例如 http_x_forwarded_for)
lua-resty-expr 提供了一种灵活而强大的方式来描述复杂条件逻辑,特别适合在 OpenResty 的上下文中进行流量控制和路由决策。
来源:豆瓜网用户自行投稿发布,如果侵权,请联系站长删除 |