Envoy Gateway中实现AWS NLB的TLS终止与HTTP后端通信
2025-07-07 18:58:17作者:邵娇湘
在云原生架构中,TLS终止是常见的网络配置模式。本文将详细介绍如何在Envoy Gateway项目中,通过AWS Network Load Balancer (NLB)实现TLS终止,并将解密后的HTTP流量转发至后端服务的完整方案。
核心配置原理
Envoy Gateway与AWS NLB集成时,TLS终止可以在两个层面实现:
- 在NLB层面终止TLS,然后以明文HTTP转发至Envoy
- 在Envoy层面终止TLS
本文重点讨论第一种方案,其优势在于:
- 减少Envoy的CPU负载
- 简化证书管理(证书直接绑定到NLB)
- 符合部分企业的安全合规要求
关键配置详解
1. Gateway资源配置
正确的Gateway资源配置需要注意以下要点:
apiVersion: gateway.networking.k8s.io/v1
kind: Gateway
metadata:
name: gw
namespace: test
spec:
gatewayClassName: envoy
infrastructure:
annotations:
service.beta.kubernetes.io/aws-load-balancer-nlb-target-type: ip
service.beta.kubernetes.io/aws-load-balancer-scheme: internal
service.beta.kubernetes.io/aws-load-balancer-ssl-cert: arn:aws:acm:us-east-2:<account>:certificate/<id>
service.beta.kubernetes.io/aws-load-balancer-ssl-negotiation-policy: ELBSecurityPolicy-TLS13-1-2-2021-06
service.beta.kubernetes.io/aws-load-balancer-ssl-ports: "443"
listeners:
- name: http
port: 80
protocol: HTTP
- name: https
port: 443
protocol: HTTP
关键点说明:
- AWS特定注解必须放在
spec.infrastructure.annotations下,而非metadata.annotations protocol: HTTP表示Envoy将接收解密后的HTTP流量- SSL证书ARN需要替换为实际的ACM证书
2. HTTP路由配置
实现HTTP到HTTPS重定向的配置示例:
apiVersion: gateway.networking.k8s.io/v1
kind: HTTPRoute
metadata:
name: ssl-redirect
spec:
parentRefs:
- name: gw
sectionName: http
rules:
- filters:
- type: RequestRedirect
requestRedirect:
scheme: https
statusCode: 301
最佳实践建议:
- 使用
sectionName引用特定监听器,比使用port更明确 - 301重定向适合永久性跳转,有利于SEO
3. HTTPS路由配置
处理TLS终止后流量的配置示例:
apiVersion: gateway.networking.k8s.io/v1
kind: HTTPRoute
metadata:
name: api-route
spec:
parentRefs:
- name: gw
sectionName: https
rules:
- matches:
- path:
type: PathPrefix
value: /api
backendRefs:
- name: api-service
port: 80
常见问题排查
如果遇到TLS握手失败(如protocol version错误),请检查:
- 注解位置:确认AWS相关注解是否放在正确位置(spec.infrastructure.annotations)
- 证书兼容性:确保NLB使用的SSL策略与客户端支持的TLS版本匹配
- 监听器协议:TLS终止在NLB时,Envoy监听器应使用HTTP而非HTTPS协议
- 安全组规则:确认NLB安全组允许443端口的入站流量
性能优化建议
- 会话保持:对于有状态应用,可在NLB启用TCP会话保持
- 健康检查:配置适当的健康检查路径和间隔
- 跨可用区:启用跨可用区负载均衡提高可用性
- 访问日志:启用NLB访问日志用于流量分析
通过以上配置,开发者可以构建一个安全、高效的TLS终止架构,充分发挥AWS NLB和Envoy Gateway各自的优势。
登录后查看全文
热门项目推荐
相关项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
yuanrongopenYuanrong runtime:openYuanrong 多语言运行时提供函数分布式编程,支持 Python、Java、C++ 语言,实现类单机编程高性能分布式运行。Go051
MiniCPM-SALAMiniCPM-SALA 正式发布!这是首个有效融合稀疏注意力与线性注意力的大规模混合模型,专为百万级token上下文建模设计。00
ebook-to-mindmapepub、pdf 拆书 AI 总结TSX01
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
541
3.77 K
Ascend Extension for PyTorch
Python
351
419
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
889
615
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
338
186
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
988
253
openGauss kernel ~ openGauss is an open source relational database management system
C++
169
233
暂无简介
Dart
778
194
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
115
141
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.35 K
759