今天我将演示如何将 OpenResty Edge 作为 Kubernetes 集群的一个功能强大的 ingress controller 使用。也就是说,当后端应用程序是运行在 Kubernetes 容器内部的时候,如何借助 OpenRest Edge 管理其流量。

Embeded image

在本教程中,我们将在一个 Edge 应用中创建一个 Kubernetes 上游。Edge 网关服务器可以运行在 Kubernetes 集群内部,也可以在其外部运行。Edge 的 Admin 服务器会通过其 API 服务器持续监控 Kubernetes 集群。而且会响应 Kubernetes 节点(或容器)的在线和离线事件,自动更新上游服务器列表。

Embeded image

如何创建及使用 Kubernetes 上游

让我们进入 OpenResty Edge 的 Admin Web 控制台。这就是我们控制台的样本部署。每个用户都有自己的本地部署。

Screenshot

首先,我们需要在一个专门的网关分区中设置一个可以连接到 Kubernetes 服务的网关服务器。

Screenshot

跳转到网关分区页面。

Screenshot

我们已经创建了一个网关分区,名为 kubernetes-test-partition。

Screenshot

分区内包含一个名为 kubernetes-test-cluster 的网关集群。

Screenshot

我们需要一个单独的网关分区,因为不是所有的网关服务器都能连接到我们的 Kubernetes 服务。

跳转到 kubernetes-test-cluster 集群。

Screenshot

在这个网关集群中已经定义了一个网关服务器。我们需要确保这个网关服务器可以连接到我们的 Kubernetes 集群。

Screenshot

创建 Kubernetes 集群

我们在 Edge 应用中创建新的 Kubernetes 上游之前,需要先在全局范围内注册 Kubernetes 集群。

跳转到 Kubernetes 页面。

Screenshot

点击这个按钮来添加一个新的 Kubernetes 集群。

Screenshot

为了接收新通知,OpenResty Edge Admin 需要建立与 Kubernetes 的 HTTPS API 服务器的连接。

输入 Kubernetes API 服务器的主机名或 IP 地址。

Screenshot

然后输入端口号。

Screenshot

接下来输入 kubernetes 集群的名称。

Screenshot

停用 SSL 证书验证。这是因为我们的 Kubernetes API 服务器的证书是自签的。

Screenshot

我们还需要一个 token 来访问 Kubernetes API 服务器,这个 token 要有足够的权限。

Screenshot

点击 “How to generate this token” 这个链接可以打开一个弹窗。

Screenshot

这里说明了如何从你自己的 Kubernetes 部署中生成一个 token。 现在让我来演示一下这个过程。

关闭这个弹窗。

Screenshot

我们需要准备一个名为 token.yml 的配置文件。下面是这个文件的一个样本。可以用它来创建一个具有读取权限的账户,以访问

Screenshot

命名空间、

Screenshot

服务、

Screenshot

端点,以及

Screenshot

Pods 对象。

Screenshot

使用以下命令创建账户。

kubectl apply -f /root/token.yml

Screenshot

最后,我们使用下面的命令来获取账户的 token。

Screenshot

“token:” 后面的文字就是我们需要的 token。

Screenshot

现在我们有了一个访问 Kubernetes API 服务器的 token。

将我们刚刚创建的 API token 粘贴到这里。

Screenshot

单击 “创建” 按钮。

Screenshot

创建 Kubernetes 上游

到这一步我们已经在全局范围内注册了 Kubernetes 集群。现在是时候在 Edge 应用程序中创建一个上游来利用这个集群了。

Screenshot

跳转到应用程序列表页。

Screenshot

我们已经准备了一个名为 www.kubernetes-edge-test.com 的 Edge 应用程序。

Screenshot

这个应用程序被映射到我们之前展示的网关分区。

Screenshot

进入这个应用。

Screenshot

进入 “Upstreams” 页面。

Screenshot

点击新建 Kubernetes 上游。

Screenshot

输入 Kubernetes 上游的名称 “my kubernetes backend”。

Screenshot

选择一个 Kubernetes 集群作为目标。

Screenshot

选择我们刚刚创建的那个 Kubernetes 集群。

Screenshot

选择目标 Kubernetes 的命名空间。

Screenshot

选择名为 “default” 的命名空间。你也可以选择其他的命名空间。

Screenshot

从列表中选择一个 Kubernetes 服务。

Screenshot

选择 “test-hello” 服务。

Screenshot

以及服务的端口。

Screenshot

在我们这个例子中是 80 端口。

Screenshot

保存新的上游。

Screenshot

现在我们成功创建了一个新的 Kubernetes 上游。

Screenshot

上游服务器地址显示在这里。

Screenshot

它们是从 Kubernetes 集群自动同步的 Kubernetes 节点或容器。

Screenshot

创建页面规则使用 Kubernetes 上游

就像普通的上游一样,我们仍然需要创建一个新的页面规则来使用这个新的 Kubernetes 上游。

跳转到页面规则页面。

Screenshot

点击这个 “新建规则” 按钮。

Screenshot

启用 Proxy 这个动作。

Screenshot

点击这个 “代理到上游” 下拉列表。

Screenshot

选择我们刚刚创建的 Kubernetes 上游 “my kubernetes backend”。

Screenshot

保存这个页面规则。

Screenshot

像往常一样,需要发布一个新的版本来推送我们刚才的改动。

Screenshot

点击这个按钮。

Screenshot

发布!

Screenshot

同步完成。

Screenshot

现在,新的页面规则已经被推送到所有的网关集群和服务器。

Embeded video

Embeded video

Embeded video

这些配置的变化不需要服务器重载、重启或二进制升级。所以它是非常高效和可扩展的。

Embeded image

测试

接下来,我们会在相应分区中找到 Edge 网关服务器来做实际的测试。

跳转到网关集群页面。

Screenshot

找到相应的网关服务器。

Screenshot

请记住它的公共 IP 地址是以 .196 结尾的。

Screenshot

复制这个 IP 地址,以便我们可以在命令行上使用它。

在终端上,尝试通过这个网关服务器访问 Kubernetes 服务。

Screenshot

注意,我们使用的是刚才复制的网关服务器的 IP 地址。

Screenshot

运行这个命令。

Screenshot

可以看到对这个服务的访问是成功的。在本教程余下的部分里,我们将修改 Kubernetes 服务的配置。

Screenshot

我们将临时把 Kubernetes 节点的数量增加到 3 个。

kubectl scale --replicas=3 deployment test-hello

Screenshot

扩展成功完成。

Screenshot

让我们检查一下新的节点。

kubectl get pods -o wide

Screenshot

现在确实有 3 个 Kubernetes 节点。

Screenshot

Edge Admin 会自动更新 Kubernetes 上游反映这个变化。

回到我们的 Edge 应用程序页面来检查一下。

Screenshot

Screenshot

返回到上游页面。

Screenshot

刷新 Upstreams 页面更新数据。

Screenshot

耶! Kubernetes 上游确实有 3 台服务器了!

Screenshot

同样地,如果 Kubernetes 节点较少,Edge Admin 也会自动更新上游。这就是我今天要讲的内容。

Screenshot

关于 OpenResty Edge

OpenResty Edge 是一款专为微服务和分布式流量架构设计的全能型网关软件,由我们自主研发。它集流量管理、私有 CDN 构建、API 网关、安全防护等功能于一体,帮助您轻松构建、管理和保护现代应用程序。OpenResty Edge 拥有业界领先的性能和可扩展性,能够满足高并发、高负载场景下的苛刻需求。它支持调度 K8s 等容器应用流量,并可管理海量域名,轻松满足大型网站和复杂应用的需求。

如果你喜欢这个教程,请订阅这个博客网站和我们的 YouTube 频道B 站频道。谢谢!

关于作者

章亦春是开源 OpenResty® 项目创始人兼 OpenResty Inc. 公司 CEO 和创始人。

章亦春(Github ID: agentzh),生于中国江苏,现定居美国湾区。他是中国早期开源技术和文化的倡导者和领军人物,曾供职于多家国际知名的高科技企业,如 Cloudflare、雅虎、阿里巴巴, 是 “边缘计算“、”动态追踪 “和 “机器编程 “的先驱,拥有超过 22 年的编程及 16 年的开源经验。作为拥有超过 4000 万全球域名用户的开源项目的领导者。他基于其 OpenResty® 开源项目打造的高科技企业 OpenResty Inc. 位于美国硅谷中心。其主打的两个产品 OpenResty XRay(利用动态追踪技术的非侵入式的故障剖析和排除工具)和 OpenResty Edge(最适合微服务和分布式流量的全能型网关软件),广受全球众多上市及大型企业青睐。在 OpenResty 以外,章亦春为多个开源项目贡献了累计超过百万行代码,其中包括,Linux 内核、Nginx、LuaJITGDBSystemTapLLVM、Perl 等,并编写过 60 多个开源软件库。

关注我们

如果您喜欢本文,欢迎关注我们 OpenResty Inc. 公司的博客网站 。也欢迎扫码关注我们的微信公众号:

我们的微信公众号

翻译

我们提供了英文版原文和中译版(本文) 。我们也欢迎读者提供其他语言的翻译版本,只要是全文翻译不带省略,我们都将会考虑采用,非常感谢!