最新发布《数智时代的AI人才粮仓模型解读白皮书(2024版)》,立即领取! 了解详情
写点什么

AWS Application Load Balancer 的高级请求路由

  • 2019-10-06
  • 本文字数:1771 字

    阅读完需:约 6 分钟

AWS Application Load Balancer 的高级请求路由

AWS Application Load Balancer 自 2016 年夏使用至今! 它们支持基于内容的路由,适用于无服务器且基于容器的应用程序,并且具有高度可扩展性。很多 AWS 客户使用现有的基于主机和路径的路由来增强 HTTP 和 HTTPS 应用程序,同时利用其他 ALB 功能,例如端口转发(非常适合基于容器的应用程序)、健康检查、服务发现、重定向、固定应答以及内置身份验证。

高级请求路由

基于主机的路由功能允许您编写规则,以使用主机标头将流量路由到所需的目标组。我们正在扩展和推广此功能,使您能够基于标准和自定义 HTTP 标头和方法、查询字符串以及源 IP 地址来编写规则(和路由流量)。我们还致力于使规则和条件更强大;规则可以有多个条件(AND 关系),每个条件可以指定与多个值的匹配(OR 关系)。


您可以使用此新功能来简化应用程序架构,无需使用代理队列进行路由,并在负载均衡器阻止不需要的流量。以下是一些用例:


  • 将人为流量与机器人/爬虫流量分开。

  • 将客户或客户组分配到单元(不同的目标组)并相应地路由流量。

  • 执行 A/B 测试。

  • 执行金丝雀或蓝绿部署。

  • 根据方法将流量路由到微服务处理程序(例如,PUT 到一个目标组或 GET 到另一个目标组)。

  • 执行基于 IP 地址或 CDN 的访问限制。

  • 有选择地将流量路由到本地或云端的目标组。

  • 为各种类型和类别的设备提供不同的页面或用户体验。

使用高级请求路由

只需编辑现有规则,即可将此功能用于现有的 Application Load Balancer。下面我将从一个简单的规则开始,即返回一个固定的纯文本响应(这篇博文中的示例仅供测试和说明;相信您的情况更实际,也更有趣):



我可以使用 curl 来测试:


$ curl http://TestALB-156468799.elb.amazonaws.com
复制代码


符合默认规则!


单击 Insert Rule(插入规则)来设置一些高级请求路由:



然后单击 Add condition(添加条件)并检查可用的选项:



选择 Http header(Http 标头)并创建一个条件,查找名为“user”且值为 jeff 的 cookie。然后创建一个返回固定响应的操作:



单击 Save(保存),等待几秒钟,然后在更改生效后发出一对请求:


$ curl http://TestALB-156468799.elb.amazonaws.com
复制代码


符合默认规则!


$ curl --cookie "user=jeff" http://TestALB-156468799.elb.amazonaws.comHello Jeff
复制代码


我还可以创建一个匹配一个或多个 IP 地址 CIDR 块的规则:



$ curl http://TestALB-156468799.elb.amazonaws.com
复制代码


Hello EC2 实例


我可以匹配查询字符串(这对 A/B 测试非常有用):



$ curl http://TestALB-156468799.elb.amazonaws.com?ABTest=A
复制代码


A/B 测试,已选择选项 A


如果我只关心是否存在特定的字段名称,也可以使用通配符:



我可以匹配标准或自定义 HTTP 方法。我可以创建一个名为 READ 的方法:



$ curl --request READ http://TestALB-156468799.elb.amazonaws.com
复制代码


已调用自定义 READ 方法


针对以下操作有很多灵活处理(并不新鲜,但绝对值得了解):



转发,将请求路由到目标组(一组 EC2 实例、一个 Lambda 函数或一个 IP 地址列表)。


重定向,生成 301(永久)或 302(找到)响应,还可用于在 HTTP 与 HTTPS 之间切换。


返回固定响应,生成带有任何所需响应代码的静态响应,如之前所展示的那样。


身份验证,使用 Amazon Cognito 或 OIDC 提供程序对请求进行身份验证(仅适用于 HTTPS 侦听器)。

注意事项

关于这个强大的新功能有以下几点注意事项:


指标 – 您可以查看规则评估和 HTTP 固定响应计数 CloudWatch 指标,以了解规则相关活动的更多信息(了解更多):



编程访问 – 您还可以使用 ALB API 和 CLI 创建、修改、检查和删除规则(即将推出 CloudFormation 支持)。


规则匹配 – 这些规则由字符串匹配提供支持,因此请仔细测试并反复检查您的规则是否按预期运行。调试和测试时,ALB 访问日志中的 matched_rule_priority 和 actions_executed 字段很有帮助(了解更多)。


限制 – 每个 ALB 最多可以有 100 条规则,不包括默认值。每条规则最多可引用 5 个值,最多可使用 5 个通配符。条件数量仅受引用的唯一值的数量限制。

现已推出

现在,所有 AWS 地区都提供高级请求路由,无需额外付费(您只需支付 Application Load Balancer 的正常价格)。


作者介绍:


Jeff Barr


AWS 首席布道师; 2004 年开始发布博客,此后便笔耕不辍。


本文转载自 AWS 技术博客。


原文链接:


https://amazonaws-china.com/cn/blogs/china/new-advanced-request-routing-for-aws-application-load-balancers/


2019-10-06 22:01701
用户头像

发布了 1835 篇内容, 共 91.9 次阅读, 收获喜欢 73 次。

关注

评论

发布
暂无评论
发现更多内容

高性能实战Alibaba Sentinel笔记,深度还原阿里微服务高并发方案

小柴说Java

Java 编程 架构 面试 后端

怎样设计一个协助中心来帮助你的顾客?

Baklib

聊聊 npm 的语义化版本(Semver)

冴羽

JavaScript 前端 npm 项目开发 semver

哪些数据被纳入元数据管理的范畴?

雨果

元数据

云堡垒机和软件堡垒机哪个好?区别是什么?

行云管家

网络安全 数据安全 堡垒机 云堡垒机

新手指南|帮助中心应该包含哪些内容?

Geek_da0866

你可能不知道,自动化元数据管理的“七宗最”?

雨果

元数据

前端培训就业后的程序员就业方向有哪些?

小谷哥

开源流式湖仓服务 Arctic 详解:并非另一套 Table Format

网易数帆

大数据 iceberg Hudi Arctic

非科班出身,开发五年之后我对编程有了新的领悟

Java永远的神

Java 编程 程序员 程序人生 计算机

重磅揭秘!10分钟10TB数据跨云、跨地域传输的技术实践

星汉未来

云原生 数据迁移 东数西算 星汉未来

手把手地教你如何建立最好的知识管理体系

Baklib

阿里云AIoT物联网平台技术集锦

阿里云AIoT

数据挖掘 运维 监控 物联网 消息中间件

低/无代码的发展将显著改变银行开发生态

易观分析

代码 银行

StarRocks 技术内幕:向量化编程精髓

StarRocks

从一条更新SQL的执行过程窥探InnoDB之REDOLOG

京东科技开发者

MySQL 数据库

数据透视表上线!如何在纯前端实现这个强大的数据分析功能?

葡萄城技术团队

前端

一文看懂流程挖掘是如何工作的

望繁信科技

延时任务-基于netty时间轮算法实现

字母哥哥

Java 架构 后端 Netty

[极致用户体验] 2行代码,让你的UI适配移动端、PC端,快来收藏

HullQin

CSS JavaScript html 前端 8月月更

这么好用的接口工具,请允许我油腻一次!

Liam

Java 开发 Postman API 开放api

听潮汐,筑灯塔,聚千帆:智慧港口全球创新实验室启航时

脑极体

首发!阿里P8顶级架构师总结的这份全网最全 JVM 知识宝典,帮你查漏补缺

了不起的程序猿

Java JVM 虚拟机 java编程 Java程序猿

toB行业知识管理的重要性

Baklib

完整实现-通过DelayQueue实现延时任务

字母哥哥

Java 架构 并发编程 后端

爆肝!阿里大佬熬夜38天整合的这份Spring Security源码手册我粉了

Java全栈架构师

Java 程序员 面试 程序人生 springsecurity

一对一直播系统源码——如何只需三步搭建

开源直播系统源码

软件开发 一对一直播源码 直播系统源码 一对一直播系统

题目新颖,内容全面!阿里巴巴又一Java面试神册开源!

Java永远的神

Java spring 程序员 面试 JVM

堡垒机可以管理哪些网络资产?咨询电话多少?

行云管家

网络安全 数据安全 堡垒机

学术加油站|面向HTAP数据库的基准评测工具研究进展

OceanBase 数据库

超全面!字节最新发布22年秋招200道Java面试题(含答案)

Java面试那些事儿

Java 编程 面试 后端 架构师

AWS Application Load Balancer 的高级请求路由_语言 & 开发_亚马逊云科技 (Amazon Web Services)_InfoQ精选文章