2019-06-05 17:36:58 +08:00
|
|
|
|
## 目录
|
2019-06-06 12:39:49 +08:00
|
|
|
|
- [**apisix**](#apisix)
|
2019-06-05 16:30:57 +08:00
|
|
|
|
- [**apisix Config**](#apisix-config)
|
2019-06-05 16:10:53 +08:00
|
|
|
|
- [**Route**](#route)
|
|
|
|
|
- [**Service**](#service)
|
|
|
|
|
- [**Consumer**](#consumer)
|
|
|
|
|
- [**Plugin**](#plugin)
|
2019-06-10 15:07:32 +08:00
|
|
|
|
- [**Upstream**](#upstream)
|
2019-08-04 09:54:30 +08:00
|
|
|
|
- [**Router**](#router)
|
2019-07-27 09:10:06 +08:00
|
|
|
|
- [**Debug mode**](#Debug-mode)
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
2019-06-06 12:39:49 +08:00
|
|
|
|
## apisix
|
|
|
|
|
|
|
|
|
|
### 插件加载流程
|
|
|
|
|
|
|
|
|
|
![](./images/flow-load-plugin.png)
|
|
|
|
|
|
|
|
|
|
### 插件内部结构
|
|
|
|
|
|
|
|
|
|
<img src="./images/flow-plugin-internal.png" width="50%" height="50%">
|
|
|
|
|
|
2019-06-05 16:30:57 +08:00
|
|
|
|
## apisix Config
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
2019-06-05 16:30:57 +08:00
|
|
|
|
通过修改本地 `conf/config.yaml` 文件完成对 apisix 服务本身的基本配置。
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
|
apisix:
|
2019-06-05 16:30:57 +08:00
|
|
|
|
node_listen: 9080 # apisix listening port
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
|
|
|
|
etcd:
|
|
|
|
|
host: "http://127.0.0.1:2379" # etcd address
|
|
|
|
|
prefix: "apisix" # apisix configurations prefix
|
|
|
|
|
timeout: 60
|
|
|
|
|
|
|
|
|
|
plugins: # plugin name list
|
|
|
|
|
- example-plugin
|
|
|
|
|
- limit-req
|
|
|
|
|
- limit-count
|
|
|
|
|
- ...
|
|
|
|
|
```
|
|
|
|
|
|
2019-06-05 16:30:57 +08:00
|
|
|
|
*注意* 不要手工修改 apisix 自身的 `conf/nginx.conf` 文件,当服务每次启动时,`apisix`
|
2019-06-05 16:10:53 +08:00
|
|
|
|
会根据 `conf/config.yaml` 配置自动生成新的 `conf/nginx.conf` 并自动启动服务。
|
|
|
|
|
|
2019-06-05 17:36:58 +08:00
|
|
|
|
[返回目录](#目录)
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
|
|
|
|
## Route
|
|
|
|
|
|
2019-08-31 13:09:47 +08:00
|
|
|
|
Route 字面意思就是路由,实际就是我们通过定义一些规则来匹配客户端的请求,然后根据匹配结果执行相应的插件,并把请求转发给到指定上游。
|
|
|
|
|
|
|
|
|
|
![](./images/router.png)
|
|
|
|
|
|
|
|
|
|
通过上图可以看到,Route 中主要包含三方面内容:Route 自身、绑定的插件(完成限流、限速等行为)和目标 Upstream 地址,除了 Route 自身是必须的,后两者均是可选的。
|
|
|
|
|
|
|
|
|
|
如果我们直接在 Route 中配置需要的所有参数,比如上面的示例图。这种方式的有点是容易设置,每个 Route 都是相对独立,对于后期管理来说自由度比较高。但当我们规则比较多的时候,缺点也就越发明显,会有比较多的重复。比如当我们需要修改某个已有 Upstream 时,就需要逐个更新每个 Route 的配置,后期管理维护成本略高。
|
|
|
|
|
|
|
|
|
|
上面提及的缺点在 APISIX 中独立抽象了 [Service](#service) 和 [Upstream](#upstream) 两个概念来解决。
|
|
|
|
|
|
|
|
|
|
Route 默认存储到路径是 `/apisix/routes/`。
|
|
|
|
|
|
|
|
|
|
下面创建的 Route 示例,是把 uri 为 "/index.html" 的请求代理到地址为 "39.97.63.215:80" 的 Upstream 服务:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
$ curl http://127.0.0.1:9080/apisix/admin/routes -X POST -i -d '
|
|
|
|
|
{
|
|
|
|
|
"uri": "/index.html",
|
|
|
|
|
"upstream": {
|
|
|
|
|
"type": "roundrobin",
|
|
|
|
|
"nodes": {
|
|
|
|
|
"39.97.63.215:80": 1
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}'
|
|
|
|
|
|
|
|
|
|
HTTP/1.1 201 Created
|
|
|
|
|
Date: Sat, 31 Aug 2019 01:17:15 GMT
|
|
|
|
|
Content-Type: text/plain
|
|
|
|
|
Transfer-Encoding: chunked
|
|
|
|
|
Connection: keep-alive
|
|
|
|
|
Server: APISIX web server
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
2019-08-31 13:09:47 +08:00
|
|
|
|
{"node":{"value":{"uri":"\/index.html","upstream":{"nodes":{"39.97.63.215:80":1},"type":"roundrobin"}},"createdIndex":61925,"key":"\/apisix\/routes\/00000000000000061925","modifiedIndex":61925},"action":"create"}
|
|
|
|
|
```
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
2019-08-31 13:09:47 +08:00
|
|
|
|
当我们接受到 201 的应答,表示该 Route 已成功创建。
|
|
|
|
|
该 Route 被存到 "/apisix/routes/00000000000000061925" 这个路径下,`00000000000000061925` 就是这条 Route 的 ID。
|
|
|
|
|
|
|
|
|
|
具体 Route 的获取、更新、删除都是依赖这个 ID 来管理维护,有时候需指定 ID 的方式来创建或更新 Route(注意这里的 uri 地址和对应的 method 与上面的例子略有不同):
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
|
|
|
|
```shell
|
2019-08-31 13:09:47 +08:00
|
|
|
|
$ curl http://127.0.0.1:9080/apisix/admin/routes/1 -X PUT -i -d '
|
2019-06-05 16:10:53 +08:00
|
|
|
|
{
|
|
|
|
|
"uri": "/index.html",
|
|
|
|
|
"upstream": {
|
|
|
|
|
"type": "roundrobin",
|
|
|
|
|
"nodes": {
|
|
|
|
|
"39.97.63.215:80": 1
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}'
|
2019-08-31 13:09:47 +08:00
|
|
|
|
HTTP/1.1 200 OK
|
|
|
|
|
Date: Sat, 31 Aug 2019 05:00:41 GMT
|
|
|
|
|
Content-Type: text/plain
|
|
|
|
|
Transfer-Encoding: chunked
|
|
|
|
|
Connection: keep-alive
|
|
|
|
|
Server: APISIX web server
|
|
|
|
|
|
|
|
|
|
{..."key":"\/apisix\/routes\/1","modifiedIndex":61921},"action":"set"}
|
2019-06-05 16:10:53 +08:00
|
|
|
|
```
|
|
|
|
|
|
2019-08-31 13:09:47 +08:00
|
|
|
|
|
2019-06-05 16:10:53 +08:00
|
|
|
|
#### Route option
|
|
|
|
|
|
|
|
|
|
|name |option |description|
|
|
|
|
|
|---------|---------|-----------|
|
2019-08-20 22:07:59 +08:00
|
|
|
|
|uri |required |除了如 `/foo/bar`、`/foo/gloo` 这种全量匹配外,使用不同 [Router](#router) 还允许更高级匹配,更多见 [Router](#router)。|
|
2019-07-04 21:17:33 +08:00
|
|
|
|
|host |optional |当前请求域名,比如 `foo.com`;也支持泛域名,比如 `*.foo.com`|
|
2019-08-24 09:51:59 +08:00
|
|
|
|
|remote_addr|optional |客户端请求 IP 地址,比如 `192.168.1.101`、`192.168.1.102`,也支持 CIDR 格式如 `192.168.1.0/24`。特别的,APISIX 也支持 IPv6 匹配,比如:`::1`,`fe80::1`, `fe80::1/64` 等。|
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|methods |optional |如果为空或没有该选项,代表没有任何 `method` 限制,也可以是一个或多个组合:GET, POST, PUT, DELETE, PATCH, HEAD, OPTIONS。|
|
2019-08-24 09:51:59 +08:00
|
|
|
|
|plugins|optional |启用的插件配置,详见 [Plugin](#plugin) |
|
2019-07-04 21:17:33 +08:00
|
|
|
|
|upstream|optional |启用的 upstream 配置,详见 [Upstream](#upstream)|
|
|
|
|
|
|upstream_id|optional |启用的 upstream id,详见 [Upstream](#upstream)|
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|service_id|optional |绑定的 Service 配置,详见 [Service](#service)|
|
|
|
|
|
|
2019-06-05 17:36:58 +08:00
|
|
|
|
[返回目录](#目录)
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
|
|
|
|
## Service
|
|
|
|
|
|
2019-06-06 10:57:40 +08:00
|
|
|
|
`Service` 是某类功能的提供者,比如订单、账户服务。它通常与上游服务抽象是一对一的,`Route`
|
2019-07-20 23:33:57 +08:00
|
|
|
|
与 `Service` 之间,通常是 N:1 的关系,即多个 `Route` 规则可以对应同一个 `Service`。
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
|
|
|
|
多个 route 规则同时绑定到一个 service 上,这些路由将具有相同的上游和插件配置,减少冗余配置。
|
|
|
|
|
|
2019-06-06 10:57:40 +08:00
|
|
|
|
比如下面的例子,先创建了一个 service,并开启了限流插件,
|
|
|
|
|
然后把 id 为 `100`、`101` 的 route 都绑定在这个 service 上。
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
|
|
|
|
```shell
|
2019-06-18 09:40:00 +08:00
|
|
|
|
curl http://127.0.0.1:9080/apisix/admin/services/200 -X PUT -d '
|
2019-06-05 16:10:53 +08:00
|
|
|
|
{
|
2019-06-13 17:25:39 +08:00
|
|
|
|
"plugins": {
|
2019-06-05 16:10:53 +08:00
|
|
|
|
"limit-count": {
|
|
|
|
|
"count": 2,
|
|
|
|
|
"time_window": 60,
|
|
|
|
|
"rejected_code": 503,
|
|
|
|
|
"key": "remote_addr"
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
"upstream": {
|
|
|
|
|
"type": "roundrobin",
|
|
|
|
|
"nodes": {
|
|
|
|
|
"39.97.63.215:80": 1
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}'
|
|
|
|
|
|
2019-06-18 09:40:00 +08:00
|
|
|
|
curl http://127.0.0.1:9080/apisix/admin/routes/100 -X PUT -d '
|
2019-06-05 16:10:53 +08:00
|
|
|
|
{
|
|
|
|
|
"methods": ["GET"],
|
|
|
|
|
"uri": "/index.html",
|
|
|
|
|
"service_id": "200"
|
|
|
|
|
}'
|
|
|
|
|
|
2019-06-18 09:40:00 +08:00
|
|
|
|
curl http://127.0.0.1:9080/apisix/admin/routes/101 -X PUT -d '
|
2019-06-05 16:10:53 +08:00
|
|
|
|
{
|
2019-06-18 09:40:00 +08:00
|
|
|
|
"methods": ["GET"],
|
2019-06-05 16:10:53 +08:00
|
|
|
|
"uri": "/foo/index.html",
|
|
|
|
|
"service_id": "200"
|
|
|
|
|
}'
|
|
|
|
|
```
|
|
|
|
|
|
2019-06-06 10:57:40 +08:00
|
|
|
|
你也可以为 route 单独制定不同的插件和参数,比如下面这个示例设置了不同的限流参数:
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
|
|
|
|
```shell
|
2019-06-18 09:40:00 +08:00
|
|
|
|
curl http://127.0.0.1:9080/apisix/admin/routes/102 -X PUT -d '
|
2019-06-05 16:10:53 +08:00
|
|
|
|
{
|
|
|
|
|
"uri": "/bar/index.html",
|
|
|
|
|
"id": "102",
|
|
|
|
|
"service_id": "200",
|
2019-06-13 17:25:39 +08:00
|
|
|
|
"plugins": {
|
2019-06-05 16:10:53 +08:00
|
|
|
|
"limit-count": {
|
|
|
|
|
"count": 2000,
|
|
|
|
|
"time_window": 60,
|
|
|
|
|
"rejected_code": 503,
|
|
|
|
|
"key": "remote_addr"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}'
|
|
|
|
|
```
|
|
|
|
|
|
2019-06-06 10:57:40 +08:00
|
|
|
|
当 route 和 service 都开启同一个插件时,route 的优先级高于 service。
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
2019-06-05 17:36:58 +08:00
|
|
|
|
[返回目录](#目录)
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
|
|
|
|
## Consumer
|
|
|
|
|
|
2019-06-11 11:09:49 +08:00
|
|
|
|
`Consumer` 是某类具体服务的消费者,主要用来表述不同用户的概念。比如不同的客户请求同一个 API,
|
2019-06-05 16:10:53 +08:00
|
|
|
|
经过用户认证体系,网关服务需知道当前请求用户身份信息,针对不同的消费用户,会有不同的限制处理逻辑。
|
|
|
|
|
|
2019-06-05 17:36:58 +08:00
|
|
|
|
[返回目录](#目录)
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
|
|
|
|
## Plugin
|
|
|
|
|
|
|
|
|
|
`Plugin` 表示将在 `HTTP` 请求/响应生命周期期间执行的插件配置。
|
2019-06-05 16:30:57 +08:00
|
|
|
|
|
2019-06-05 16:10:53 +08:00
|
|
|
|
`Plugin` 配置可直接绑定在 `Route` 上,也可以被绑定在 `Service` 或 `Consumer`上。而对于同一
|
|
|
|
|
个插件的配置,只能有一份是有效的,配置选择优先级总是 `Consumer` > `Route` > `Service`。
|
|
|
|
|
|
2019-06-05 16:30:57 +08:00
|
|
|
|
在 `conf/config.yaml` 中,可以声明本地 apisix 节点都支持哪些插件。这是个白名单机制,不在该
|
2019-06-05 16:10:53 +08:00
|
|
|
|
白名单的插件配置,都将会被自动忽略。这个特性可用于临时关闭或打开特定插件,应对突发情况非常有效。
|
|
|
|
|
|
|
|
|
|
插件的配置可以被直接绑定在指定 route 中,也可以被绑定在 service 中,不过 route 中的插件配置
|
|
|
|
|
优先级更高。
|
|
|
|
|
|
|
|
|
|
一个插件在一次请求中只会执行一次,即使被同时绑定到多个不同对象中(比如 route 或 service)。
|
2019-06-28 16:36:02 +08:00
|
|
|
|
插件运行先后顺序是根据插件自身的优先级来决定的,例如:[example-plugin](../doc/plugins/example-plugin.lua#L16)。
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
2019-06-13 17:25:39 +08:00
|
|
|
|
插件配置作为 route 或 service 的一部分提交的,放到 `plugins` 下。它内部是使用插件
|
2019-06-05 16:10:53 +08:00
|
|
|
|
名字作为哈希的 key 来保存不同插件的配置项。
|
|
|
|
|
|
|
|
|
|
```json
|
|
|
|
|
{
|
|
|
|
|
...
|
2019-06-13 17:25:39 +08:00
|
|
|
|
"plugins": {
|
2019-06-05 16:10:53 +08:00
|
|
|
|
"limit-count": {
|
|
|
|
|
"count": 2,
|
|
|
|
|
"time_window": 60,
|
|
|
|
|
"rejected_code": 503,
|
|
|
|
|
"key": "remote_addr"
|
|
|
|
|
},
|
|
|
|
|
"prometheus": {}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
并不是所有插件都有具体配置项,比如 `prometheus` 下是没有任何具体配置项,这时候用一个空的对象
|
|
|
|
|
标识即可。
|
|
|
|
|
|
2019-06-05 17:44:54 +08:00
|
|
|
|
目前 apisix 已支持插件:
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
2019-06-28 16:36:02 +08:00
|
|
|
|
* [key-auth](../doc/plugins/key-auth-cn.md)
|
|
|
|
|
* [limit-count](../doc/plugins/limit-count-cn.md)
|
|
|
|
|
* [limit-req](../doc/plugins/limit-req-cn.md)
|
|
|
|
|
* [prometheus](../doc/plugins/prometheus.md)
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
2019-06-05 17:36:58 +08:00
|
|
|
|
[返回目录](#目录)
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
|
|
|
|
## Upstream
|
|
|
|
|
|
|
|
|
|
上游对象表示虚拟主机名,可用于通过多个服务(目标)对传入请求进行负载均衡。
|
|
|
|
|
|
2019-06-05 16:30:57 +08:00
|
|
|
|
上游的配置使用方法,与 `plugin` 非常相似,也可以同时被绑定到 `route` 或 `service` 上,并根据优先级决
|
|
|
|
|
定执行顺序。
|
|
|
|
|
|
2019-07-18 16:09:30 +08:00
|
|
|
|
APISIX 支持对上游的健康检查,你可以设置需要检查的 host、uri、失败和恢复的次数等。
|
|
|
|
|
|
2019-06-05 16:30:57 +08:00
|
|
|
|
#### 配置参数
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
2019-07-22 13:13:34 +08:00
|
|
|
|
* `type`:`roundrobin` 或 `chash`
|
|
|
|
|
* `roundrobin`:支持权重的负载
|
|
|
|
|
* `chash`:一致性 `hash`
|
|
|
|
|
* `nodes`: 上游机器地址列表(目前仅支持 IP+Port 方式)
|
|
|
|
|
* `key`: 该选项只有类型是 `chash` 才有效。根据 `key` 来查找对应的 node `id`,相同的
|
2019-06-11 12:20:57 +08:00
|
|
|
|
`key` 在同一个对象中,永远返回相同 id 。
|
2019-07-22 13:13:34 +08:00
|
|
|
|
* `retries`: APISIX 将使用底层的 Nginx 重试机制将请求传递给下一个上游。这是一个可选项,默认是不启用重试机制。
|
|
|
|
|
* `checks`: 配置健康检查的参数。
|
2019-08-30 10:27:39 +08:00
|
|
|
|
* `scheme`: 转发到上游的 `schema` 协议,可以是 `http` 或 `https`,默认 `http` 协议。
|
2019-08-30 10:15:58 +08:00
|
|
|
|
* `uri`: 转发到上游的新 `uri` 地址。
|
|
|
|
|
* `host`: 转发到上游的新 `host`。
|
|
|
|
|
* `enable_websocket`: 是否启用 websocket (布尔值),默认不启用。
|
2019-06-11 12:20:57 +08:00
|
|
|
|
|
|
|
|
|
创建上游对象用例:
|
2019-06-05 16:10:53 +08:00
|
|
|
|
|
|
|
|
|
```json
|
2019-06-18 09:40:00 +08:00
|
|
|
|
curl http://127.0.0.1:9080/apisix/admin/upstreams/1 -X PUT -d '
|
2019-06-05 16:10:53 +08:00
|
|
|
|
{
|
2019-06-11 12:20:57 +08:00
|
|
|
|
"type": "roundrobin",
|
|
|
|
|
"nodes": {
|
|
|
|
|
"127.0.0.1:80": 1,
|
|
|
|
|
"127.0.0.2:80": 1,
|
|
|
|
|
"127.0.0.3:80": 1
|
|
|
|
|
}
|
|
|
|
|
}'
|
|
|
|
|
|
2019-06-18 09:40:00 +08:00
|
|
|
|
curl http://127.0.0.1:9080/apisix/admin/upstreams/2 -X PUT -d '
|
2019-06-11 12:20:57 +08:00
|
|
|
|
{
|
|
|
|
|
"type": "chash",
|
|
|
|
|
"key": "remote_addr",
|
|
|
|
|
"nodes": {
|
|
|
|
|
"127.0.0.1:80": 1,
|
|
|
|
|
"127.0.0.2:80": 1
|
|
|
|
|
}
|
|
|
|
|
}'
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
上游对象创建后,均可以被具体 `route` 或 `service` 引用,例如:
|
|
|
|
|
|
|
|
|
|
```shell
|
2019-06-18 09:40:00 +08:00
|
|
|
|
curl http://127.0.0.1:9080/apisix/admin/routes/1 -X PUT -d '
|
2019-06-11 12:20:57 +08:00
|
|
|
|
{
|
|
|
|
|
"uri": "/index.html",
|
2019-06-18 09:40:00 +08:00
|
|
|
|
"upstream_id": 2
|
2019-06-11 12:20:57 +08:00
|
|
|
|
}'
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
为了方便使用,也可以直接把上游地址直接绑到某个 `route` 或 `service` ,例如:
|
|
|
|
|
|
|
|
|
|
```shell
|
2019-06-18 09:40:00 +08:00
|
|
|
|
curl http://127.0.0.1:9080/apisix/admin/routes/1 -X PUT -d '
|
2019-06-11 12:20:57 +08:00
|
|
|
|
{
|
|
|
|
|
"uri": "/index.html",
|
2019-06-13 17:25:39 +08:00
|
|
|
|
"plugins": {
|
2019-06-11 12:20:57 +08:00
|
|
|
|
"limit-count": {
|
|
|
|
|
"count": 2,
|
|
|
|
|
"time_window": 60,
|
|
|
|
|
"rejected_code": 503,
|
|
|
|
|
"key": "remote_addr"
|
|
|
|
|
}
|
|
|
|
|
},
|
2019-06-05 16:10:53 +08:00
|
|
|
|
"upstream": {
|
|
|
|
|
"type": "roundrobin",
|
|
|
|
|
"nodes": {
|
2019-06-11 12:20:57 +08:00
|
|
|
|
"39.97.63.215:80": 1
|
2019-06-05 16:10:53 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-06-11 12:20:57 +08:00
|
|
|
|
}'
|
2019-06-05 16:10:53 +08:00
|
|
|
|
```
|
|
|
|
|
|
2019-07-18 16:09:30 +08:00
|
|
|
|
下面是一个配置了健康检查的示例:
|
|
|
|
|
```shell
|
|
|
|
|
curl http://127.0.0.1:9080/apisix/admin/routes/1 -X PUT -d '
|
|
|
|
|
{
|
|
|
|
|
"uri": "/index.html",
|
|
|
|
|
"plugins": {
|
|
|
|
|
"limit-count": {
|
|
|
|
|
"count": 2,
|
|
|
|
|
"time_window": 60,
|
|
|
|
|
"rejected_code": 503,
|
|
|
|
|
"key": "remote_addr"
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
"upstream": {
|
|
|
|
|
"nodes": {
|
|
|
|
|
"39.97.63.215:80": 1
|
|
|
|
|
}
|
|
|
|
|
"type": "roundrobin",
|
2019-07-22 13:13:34 +08:00
|
|
|
|
"retries": 2,
|
2019-07-18 16:09:30 +08:00
|
|
|
|
"checks": {
|
|
|
|
|
"active": {
|
|
|
|
|
"http_path": "/status",
|
|
|
|
|
"host": "foo.com",
|
|
|
|
|
"healthy": {
|
|
|
|
|
"interval": 2,
|
|
|
|
|
"successes": 1
|
|
|
|
|
},
|
|
|
|
|
"unhealthy": {
|
|
|
|
|
"interval": 1,
|
|
|
|
|
"http_failures": 2
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}'
|
|
|
|
|
```
|
|
|
|
|
|
2019-08-04 09:54:30 +08:00
|
|
|
|
更多细节可以参考[健康检查的文档](health-check.md)。
|
2019-07-18 16:09:30 +08:00
|
|
|
|
|
2019-06-05 17:36:58 +08:00
|
|
|
|
[返回目录](#目录)
|
2019-07-27 09:10:06 +08:00
|
|
|
|
|
|
|
|
|
|
2019-08-04 09:54:30 +08:00
|
|
|
|
## Router
|
|
|
|
|
|
|
|
|
|
APISIX 区别于其他 API 网关的一大特点是允许用户选择不同路由实现来更好匹配自由业务。这样可以更好的在性能、自由之间做最佳选择。
|
|
|
|
|
|
|
|
|
|
在本地配置 `conf/config.yaml` 中设置最符合自身业务需求的路由,可获得更好的匹配效率。
|
|
|
|
|
|
|
|
|
|
* `apisix.router.http`: HTTP 请求路由。
|
2019-08-20 22:07:59 +08:00
|
|
|
|
* `radixtree_uri`: (默认)只使用 `uri` 作为主索引。基于 `radix tree` 引擎,支持全量和深前缀匹配,更多见 [如何使用 libradixtree](libradixtree.md)。
|
2019-08-12 09:04:41 +08:00
|
|
|
|
* `绝对匹配`:完整匹配给定的 `uri` ,比如 `/foo/bar`,`/foo/glo`。
|
|
|
|
|
* `前缀匹配`:末尾使用 `*` 代表给定的 `uri` 是前缀匹配。比如 `/foo*`,则允许匹配 `/foo/`、`/foo/a`和`/foo/b`等。
|
2019-08-12 16:52:46 +08:00
|
|
|
|
* `匹配优先级`:优先尝试绝对匹配,若无法命中绝对匹配,再尝试前缀匹配。
|
2019-08-20 22:07:59 +08:00
|
|
|
|
* `r3_uri`: 只使用 `uri` 作为主索引(基于 r3 引擎)。基于 `r3` 的 trie tree 是支持正则匹配的,比如 `/foo/{:\w+}/{:\w+}`,更多见 [如何使用 r3](libr3.md)。
|
|
|
|
|
* `r3_host_uri`: 使用 `host + uri` 作为主索引(基于 r3 引擎),对当前请求会同时匹配 host 和 uri。
|
2019-08-04 09:54:30 +08:00
|
|
|
|
|
|
|
|
|
* `apisix.router.ssl`: SSL 加载匹配路由。
|
2019-08-20 22:07:59 +08:00
|
|
|
|
* `radixtree_sni`: 默认值,使用 `SNI` (Server Name Indication) 作为主索引(基于 radixtree 引擎)。
|
|
|
|
|
* `r3_sni`: 使用 `SNI` (Server Name Indication) 作为主索引(基于 r3 引擎)。
|
2019-08-04 09:54:30 +08:00
|
|
|
|
|
|
|
|
|
[返回目录](#目录)
|
|
|
|
|
|
2019-07-27 09:10:06 +08:00
|
|
|
|
## Debug mode
|
|
|
|
|
|
|
|
|
|
开启调试模式后,会在请求应答时,输出更多的内部信息,比如加载了哪些插件等。
|
|
|
|
|
|
|
|
|
|
设置 `conf/config.yaml` 中的 `apisix.enable_debug` 为 `true`,即可开启调试模式。
|
|
|
|
|
|
|
|
|
|
比如对 `/hello` 开启了 `limit-conn`和`limit-count`插件,这时候应答头中会有 `Apisix-Plugins: limit-conn, limit-count` 出现。
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
$ curl http://127.0.0.1:1984/hello -i
|
|
|
|
|
HTTP/1.1 200 OK
|
|
|
|
|
Content-Type: text/plain
|
|
|
|
|
Transfer-Encoding: chunked
|
|
|
|
|
Connection: keep-alive
|
|
|
|
|
Apisix-Plugins: limit-conn, limit-count
|
|
|
|
|
X-RateLimit-Limit: 2
|
|
|
|
|
X-RateLimit-Remaining: 1
|
|
|
|
|
Server: openresty
|
|
|
|
|
|
|
|
|
|
hello world
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
[返回目录](#目录)
|