- 概述
- 快速安装
- APISIX 控制台
- 动态负载均衡
- 限流限速
- 身份验证
- 健康检查
- 彩蛋
5.1 放假写的。
啊!我是真的认真!!!
1. 概述
APISIX 是基于 OpenResty + etcd 实现的云原生、高性能、可扩展的微服务 API 网关。它是国人开源,目前已经进入 Apache 进行孵化,牛逼!!!
OpenResty:通过 Lua 扩展 NGINX 实现的可伸缩的 Web 平台。
etcd:Key/Value 存储系统。
APISIX 通过插件机制,提供了动态负载平衡、身份验证、限流限速等等功能,当然我们也可以自己开发插件进行拓展。
整体架构
- 动态负载均衡:跨多个上游服务的动态负载均衡,目前已支持 round-robin 轮询和一致性哈希算法。
- 身份验证:支持 key-auth、JWT、basic-auth、wolf-rbac 等多种认证方式。
- 限流限速:可以基于速率、请求数、并发等维度限制。
并且 APISIX 还支持 A/B 测试、金丝雀发布(灰度发布)、蓝绿部署、监控报警、服务可观测性、服务治理等等高级功能,这在作为微服务 API 网关非常重要的特性。
APISIX 的文档非常齐全,由于它是国人开源,所以文档也是中文友好。因此,艿艿这里就不哔哔介绍,胖友可以后续可以阅读如下:
- 《APISIX 官方文档 —— 简介》
- 《APISIX 官方文档 —— 插件》
- 《APISIX 官方文档 —— 白皮书》
下面,我们正式进入 APISIX 的极简入门之旅。
2. 快速安装
在《APISIX 官方文档 —— 安装》中,介绍了源码包、RPM 包、Luarocks、Docker 四种安装方式。这里我们使用 CentOS 7.X 系统,所以采用 RPM 包。
因为 APISIX 是基于 OpenResty + etcd 来实现,所以需要安装它们两。
2.1 安装 OpenResty
安装 OpenResty,使用如下命令:
# 安装 OpenResty 的 YUM 软件源
$ yum install yum-utils
$ yum-config-manager --add-repo https://openresty.org/package/centos/openresty.repo
# 安装 OpenResty 软件
$ yum install -y openresty
2.2 安装 etcd
安装 etcd,使用如下命令:
# 安装 etcd
$ yum install -y etcd
# 启动 etcd
$ service etcd start
2.3 安装 APISIX
安装 APISIX,使用如下命令:
友情提示:这里我们安装的 APISIX 的版本是 1.2 版本。
最新版本的,可以从《APISIX 官方文档 —— 构建 Apache APISIX》获取。
# 安装 APISIX
$ yum install -y https://github