OpenResty Edge 中的 Sticky Cookie 简介

今天,我将演示在 OpenResty Edge 中如何启用 Sticky Cookie。

Embeded image

首先在启用 Sticky Cookie 的情况下发送两个请求,我们会看到它们被发送到了同一个后端服务器。

Embeded video

Embeded video

Embeded video

之后在禁用 Sticky Cookie 的情况下再发送两个请求,然后会观察到这次的两个请求被发送到了两个不同的后台服务器。

Embeded video

Embeded video

Embeded video

为示例应用启用 Sticky Cookie

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

Screenshot

我们可以继续使用之前的示例应用,test-edge.com。

Screenshot

进入该应用程序。

Screenshot

转到 “Upstreams” 页面。

Screenshot

我们已经定义了一个上游。

Screenshot

这个上游目前有一个上游服务器。

Screenshot

我们需要两个上游服务器。现在再增加一个服务器。

Screenshot

点击 “Add a new upstream server” 按钮。

Screenshot

输入上游服务器的主机名。

Screenshot

检查一下上游服务器是否可用。

Screenshot

可以看到返回了开源 OpenResty 的默认主页,与预期结果相符。

保存上游。

Screenshot

转到 “Page Rules” 页面。

Screenshot

Screenshot

在之前的教程中我们已经设置了一个反向代理的页面规则。

编辑这个页面规则,启用 Sticky Cookie。

Screenshot

打开 Sticky Cookie 的开关。

Screenshot

由于我们的上游服务器是在一个上游集群里面,这里我们选择使用服务器级别的 Sticky Cookie。

Screenshot

选择服务器级别。

Screenshot

这里我们可以设置 Sticky Cookie 的过期时间。

Screenshot

使用默认值 0,代表永远不会过期。

保存这个页面规则。

Screenshot

接下来,我们将会创建一个动态指标来查看请求的分布。 注意对于 Sticky Cookie 的设置来说这一步并不是必须的。Sticky Cookie 功能不依赖任何动态指标。

Screenshot

单击 “New Metric” 按钮。

Screenshot

我们把这个动态指标命名为 “Upstream Server Request Count”。

Screenshot

添加一个描述。

Screenshot

设置上报间隔为 10 秒。

Screenshot

输入 Metric SQL 语句。它将选择上游服务器地址。

Screenshot

从所有的请求中。

Screenshot

并且按照上游服务器地址分组显示。

Screenshot

保存这个指标。

Screenshot

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

Screenshot

点击这个按钮。

Screenshot

发布!

Screenshot

新版本现在已经同步到所有的网关服务器上了。

Screenshot

刚才的改动已经被推送到所有的网关集群和服务器。

Embeded video

Embeded video

Embeded video

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

Embeded image

测试

现在让我们来发送两个请求。发送第一个请求。

Screenshot

发送第二个请求。

Screenshot

所有请求发送成功。

来看一下动态指标所记录的数据。

Screenshot

选择柱状图。

Screenshot

Screenshot

可以看到所有请求都被发送到同一个上游服务器上。

正如下方图片所显示的那样。

Embeded video

Embeded video

Embeded video

禁用 Sticky Cookie

接下来,我们将演示禁用 Sticky Cookie 的情况。

Screenshot

先清理一下指标数据。

Screenshot

这里需要点击确认。

Screenshot

清理工作已经完成,现在来禁用 Sticky Cookie。

Screenshot

再次编辑这个页面规则。

Screenshot

关闭 “Sticky Cookie” 开关。

Screenshot

注意,均衡策略是 “Round Robin”。

Screenshot

保存页面规则。

Screenshot

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

Screenshot

点击这个按钮。

Screenshot

发布!

Screenshot

新版本现在已经同步到所有的网关服务器上了。

Screenshot

测试

接下来,再次发送两个请求。

发送第一个请求。

Screenshot

发送第二个请求。

Screenshot

所有请求发送完成。

重新检查动态指标。

Screenshot

点击柱状图。

Screenshot

可以看到这两个请求分别访问了不同的上游服务器。

Screenshot

正如下方图片显示的那样。

Embeded video

Embeded video

Embeded video

我们可以通过 Sticky Cookie 来让客户端和上游集群或上游服务器保持关联。这就是我今天想讲的内容。

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

关于本文和关联视频

本文和相关联的视频都是完全由我们的 OpenResty Showman 产品从一个简单的剧本文件自动生成的。

关于作者

章亦春是开源 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. 公司的博客网站 。也欢迎扫码关注我们的微信公众号:

我们的微信公众号

翻译

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