常见问题

    APISIX 和其他的 API 网关有什么不同之处?

    APISIX 基于 etcd 来完成配置的保存和同步,而不是 postgres 或者 MySQL 这类关系型数据库。 这样不仅去掉了轮询,让代码更加的简洁,配置同步也更加实时。同时系统也不会存在单点,可用性更高。

    另外,APISIX 具备动态路由和插件热加载,特别适合微服务体系下的 API 管理。

    APISIX 的性能怎么样?

    APISIX 设计和开发的目标之一,就是业界最高的性能。具体测试数据见这里:

    APISIX 是当前性能最好的 API 网关,单核 QPS 达到 2.3 万,平均延时仅有 0.6 毫秒。

    是的,在 0.6 版本中我们内置了 dashboard,你可以通过 web 界面来操作 APISIX 了。

    我可以自己写插件吗?

    当然可以,APISIX 提供了灵活的自定义插件,方便开发者和企业编写自己的逻辑。

    如何开发插件

    我们为什么选择 etcd 作为配置中心?

    对于配置中心,配置存储只是最基本功能,APISIX 还需要下面几个特性:

    1. 集群支持
    2. 事务
    3. 历史版本管理
    4. 变化通知
    5. 高性能

    遇到 luarocks 慢的问题,有以下两种可能:

    1. luarocks 安装所使用的服务器不能访问
    2. 你所在的网络到 github 服务器之间有地方对 协议进行封锁

    针对第一个问题,你可以使用 https_proxy 或者使用 --server 选项来指定一个你可以访问或者访问更快的 luarocks 服务。 运行 luarocks config rocks_servers 命令(这个命令在 luarocks 3.0 版本后开始支持) 可以查看有哪些可用服务。

    如果使用代理仍然解决不了这个问题,那可以在安装的过程中添加 --verbose 选项来查看具体是慢在什么地方。排除前面的 第一种情况,只可能是第二种,git 协议被封。这个时候可以执行 git config --global url."https://".insteadOf git:// 命令使用 https 协议替代。

    如何通过 APISIX 支持灰度发布?

    比如,foo.com/product/index.html?id=204&page=2, 根据 URL 中 query string 中的 id 作为条件来灰度发布:

    1. A组:id <= 1000

    可以这么做:

    更多的 lua-resty-radixtree 匹配操作,可查看操作列表:

    如何支持 http 自动跳转到 https?

    比如,将 http://foo.com 重定向到 https://foo.com

    有几种不同的方法来实现:

    1. 直接使用 redirect 插件的 http_to_https 功能:
    1. curl http://127.0.0.1:9080/apisix/admin/routes/1 -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PUT -d '
    2. {
    3. "uri": "/hello",
    4. "host": "foo.com",
    5. "plugins": {
    6. "redirect": {
    7. }
    8. }
    9. }'
    1. 结合高级路由规则 varsredirect 插件一起使用:
    1. 使用serverless插件:
    1. curl -i http://127.0.0.1:9080/apisix/admin/routes/1 -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PUT -d '
    2. {
    3. "uri": "/hello",
    4. "plugins": {
    5. "serverless-pre-function": {
    6. "phase": "rewrite",
    7. }
    8. }
    9. }'

    响应体应该是:

    1. HTTP/1.1 301 Moved Permanently
    2. Date: Mon, 18 May 2020 02:56:04 GMT
    3. Content-Length: 166
    4. Connection: keep-alive
    5. Location: https://foo.com/hello
    6. Server: APISIX web server
    7. <html>
    8. <head><title>301 Moved Permanently</title></head>
    9. <body>
    10. <center><h1>301 Moved Permanently</h1></center>
    11. <hr><center>openresty</center>
    12. </body>
    13. </html>

    默认的APISIX日志等级为warn,如果需要查看core.log.info的打印结果需要将日志等级调整为info

    具体步骤:

    1、修改conf/config.yaml中的nginx log配置参数error_log_level: "warn"error_log_level: "info"

    2、重启APISIX

    之后便可以在logs/error.log中查看到info的日志了。

    如何加载自己编写的插件

    Apache APISIX 的插件支持热加载,如果你的 APISIX 节点打开了 Admin API,那么对于新增/删除/修改插件等场景,均可以通过调用 HTTP 接口的方式热加载插件,不需要重启服务。

    如果你的 APISIX 节点并没有打开 Admin API,那么你可以通过手动 reload APISIX 的方式加载插件。

    1. apisix reload