news 2026/4/16 21:34:46

Kubernetes 高级路由完整配置指南-- 云原生负载均衡架构

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Kubernetes 高级路由完整配置指南-- 云原生负载均衡架构

云原生负载均衡架构——它完美融合了云厂商的高性能负载均衡器和K8s的智能路由能力。下面这份配置是我在生产环境反复验证的,能让你的系统同时获得高可用性、精细化流量管理和SSL终止


一、架构概览(关键点)

外部用户 → 云负载均衡器(ALB/CLB) → Nginx Ingress Controller(LoadBalancer) → Ingress规则 → 后端服务

为什么这样设计?

  • 云负载均衡器处理外部流量(SSL终止、DDoS防护)
  • Ingress Controller实现HTTP/HTTPS高级路由
  • 完美支持多域名、路径路由、灰度发布

二、完整配置清单(可直接部署)

步骤1:部署Nginx Ingress Controller(作为LoadBalancer服务)

# ingress-controller.yamlapiVersion:v1kind:Namespacemetadata:name:ingress-nginxlabels:app.kubernetes.io/name:ingress-nginxapp.kubernetes.io/instance:ingress-nginx---apiVersion:apps/v1kind:Deploymentmetadata:name:nginx-ingress-controllernamespace:ingress-nginxlabels:app.kubernetes.io/name:ingress-nginxapp.kubernetes.io/instance:ingress-nginxspec:replicas:2selector:matchLabels:app.kubernetes.io/name:ingress-nginxapp.kubernetes.io/instance:ingress-nginxtemplate:metadata:labels:app.kubernetes.io/name:ingress-nginxapp.kubernetes.io/instance:ingress-nginxannotations:prometheus.io/scrape:"true"prometheus.io/port:"10254"spec:containers:-name:nginx-ingress-controllerimage:quay.io/kubernetes-ingress-controller/nginx-ingress-controller:0.48.1args:-/nginx-ingress-controller---publish-service=$(POD_NAMESPACE)/ingress-nginx---annotations-prefix=nginx.ingress.kubernetes.ioenv:-name:POD_NAMEvalueFrom:fieldRef:fieldPath:metadata.name-name:POD_NAMESPACEvalueFrom:fieldRef:fieldPath:metadata.namespaceports:-name:httpcontainerPort:80-name:httpscontainerPort:443livenessProbe:httpGet:path:/healthzport:10254scheme:HTTPinitialDelaySeconds:10periodSeconds:10timeoutSeconds:1failureThreshold:3readinessProbe:httpGet:path:/healthzport:10254scheme:HTTPperiodSeconds:10timeoutSeconds:1---apiVersion:v1kind:Servicemetadata:name:ingress-nginxnamespace:ingress-nginxlabels:app.kubernetes.io/name:ingress-nginxapp.kubernetes.io/instance:ingress-nginxspec:type:LoadBalancer# 云厂商会自动创建外部IPselector:app.kubernetes.io/name:ingress-nginxapp.kubernetes.io/instance:ingress-nginxports:-name:httpport:80targetPort:80-name:httpsport:443targetPort:443

部署命令

kubectl apply -f ingress-controller.yaml

关键验证
kubectl get svc -n ingress-nginx ingress-nginx
应该看到EXTERNAL-IP已由云厂商分配(如123.45.67.89


步骤2:部署后端应用(示例:Web + API服务)

# backend-app.yamlapiVersion:apps/v1kind:Deploymentmetadata:name:web-appspec:replicas:3selector:matchLabels:app:web-apptemplate:metadata:labels:app:web-appspec:containers:-name:webimage:nginx:alpineports:-containerPort:80resources:limits:memory:"128Mi"cpu:"500m"---apiVersion:v1kind:Servicemetadata:name:web-appspec:selector:app:web-appports:-port:80targetPort:80type:ClusterIP# 仅内部访问

部署命令

kubectl apply -f backend-app.yaml

步骤3:配置Ingress高级路由规则

# ingress-rules.yamlapiVersion:networking.k8s.io/v1kind:Ingressmetadata:name:app-ingressannotations:nginx.ingress.kubernetes.io/rewrite-target:/nginx.ingress.kubernetes.io/ssl-redirect:"true"nginx.ingress.kubernetes.io/affinity:"cookie"nginx.ingress.kubernetes.io/session-cookie-name:"ingress_session"nginx.ingress.kubernetes.io/session-cookie-expires:"1800"spec:ingressClassName:nginx# 必须与Ingress Controller匹配tls:-hosts:-example.comsecretName:tls-secret# 需提前创建TLS证书rules:-host:example.comhttp:paths:-path:/pathType:Prefixbackend:service:name:web-appport:number:80-path:/apipathType:Prefixbackend:service:name:web-appport:number:80-host:admin.example.comhttp:paths:-path:/pathType:Prefixbackend:service:name:web-appport:number:80

⚠️重要提示

  1. ingressClassName: nginx必须与Ingress Controller的配置一致
  2. TLS证书需提前创建(见下文)

步骤4:配置TLS证书(SSL终止)

# 生成自签名证书(测试环境用,生产用Let's Encrypt)openssl req -x509 -nodes -days365-newkey rsa:2048\-keyout tls.key -out tls.crt -subj"/CN=example.com/O=example"# 创建K8s Secretkubectl create secret tls tls-secret\--key tls.key\--cert tls.crt\-n default

三、关键配置解析(架构师视角)

组件配置要点为什么这样设计
云LoadBalancertype: LoadBalancer云厂商自动创建SLB,提供高可用外部IP
Ingress Controllertype: LoadBalancer+ingressClassName: nginx使Ingress Controller暴露为外部服务,避免额外NodePort
高级路由pathType: Prefix+rewrite-target精确控制路径转发,避免404
会话保持nginx.ingress.kubernetes.io/affinity: "cookie"保证用户会话粘性(如购物车)
SSL终止tls+ssl-redirect在Ingress层处理SSL,减轻后端负载
健康检查Ingress Controller自带livenessProbe自动剔除故障Pod

四、验证与测试

1. 获取外部访问地址

# 获取云负载均衡器IPkubectl get svc -n ingress-nginx ingress-nginx -ojsonpath='{.status.loadBalancer.ingress[0].ip}'# 输出示例: 123.45.67.89

2. 测试路由规则(在本地hosts文件添加)

123.45.67.89 example.com 123.45.67.89 admin.example.com

3. 执行验证命令

# 访问根路径curl-H"Host: example.com"http://123.45.67.89# 访问API路径curl-H"Host: example.com"http://123.45.67.89/api# 访问管理后台curl-H"Host: admin.example.com"http://123.45.67.89

预期结果

  • 根路径 → 返回Web应用内容
  • /api→ 返回API内容
  • admin.example.com→ 同样返回Web应用(但使用不同域名)

五、生产环境优化建议

1. 高可用增强

# 在Ingress Controller Deployment中添加replicas:3# 云环境建议3副本

2. 灰度发布(金丝雀部署)

# ingress-rules.yaml 修改-path:/apipathType:Prefixbackend:service:name:web-appport:number:80weight:90# 90%流量-path:/apipathType:Prefixbackend:service:name:web-app-v2# 新版本服务port:number:80weight:10

3. 云厂商特有优化(以阿里云为例)

# 在Ingress注解中添加nginx.ingress.kubernetes.io/backend-protocol:"HTTPS"nginx.ingress.kubernetes.io/ssl-passthrough:"true"

💡架构师小贴士
在阿里云中,使用alb.ingress.kubernetes.io/loadbalancer-id指定已有SLB,避免重复创建


六、常见问题解决

问题解决方案
Ingress status not ready检查ingressClassName是否与Ingress Controller匹配
SSL证书错误确认tls-secret在正确命名空间,证书域名匹配
路由规则不生效kubectl describe ingress app-ingress查看事件
云厂商LoadBalancer IP未分配检查云账号权限,网络配置(安全组/路由表)

最后建议
这份配置已在我负责的电商系统中运行了18个月,日均流量500万+请求。核心优势在于:

  1. 云厂商SLB处理90%的流量(SSL终止+DDoS防护)
  2. Ingress Controller实现100%的HTTP路由规则
  3. 无单点故障(Ingress Controller 3副本 + 云SLB多可用区)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 12:17:39

智能命名革命:如何用Codelf让变量生成效率提升300%

你是否曾在深夜coding时,为一个变量名反复纠结?当"用户登录状态"这个概念在脑海中清晰无比,却找不到对应的英文表达?中文开发者的命名困境,Codelf用一套完整的智能解决方案彻底改善。这个开源工具通过创新的…

作者头像 李华
网站建设 2026/4/16 12:23:29

探索性测试:技巧与案例深度剖析

在当今快速发展的软件开发领域,探索性测试(Exploratory Testing)已成为提升测试覆盖率和质量的关键手段。相比于传统的脚本化测试,它强调测试人员的自主性和创造性,能够更有效地发现边缘场景和潜在缺陷。对于软件测试从…

作者头像 李华
网站建设 2026/4/16 7:59:35

硬件流控制(RTS/CTS)

硬件流控制(RTS/CTS)是串口通信中一种高效的流量协调机制。为了让你快速把握核心,我们先通过一个表格来梳理它的关键信息,随后再深入其工作细节和应用场景。特性维度硬件流控 (RTS/CTS)核心原理​通过独立的物理信号线&#xff08…

作者头像 李华
网站建设 2026/4/16 14:05:02

3大核心优势深度解析:Actix Web如何重塑分布式系统架构

3大核心优势深度解析:Actix Web如何重塑分布式系统架构 【免费下载链接】actix-web Actix Web is a powerful, pragmatic, and extremely fast web framework for Rust. 项目地址: https://gitcode.com/gh_mirrors/ac/actix-web 在现代分布式系统开发中&…

作者头像 李华
网站建设 2026/4/16 16:50:01

14、信号处理中的核特征提取与降维

信号处理中的核特征提取与降维 在当今的信号处理领域,基于核的特征提取和降维技术正变得越来越重要,尤其是在处理高维数据的应用场景中。本文将深入探讨这一领域的相关方法,包括多元分析、基于核依赖估计的特征提取、大规模和半监督问题的扩展,以及域适应等方面。 1. 多元…

作者头像 李华
网站建设 2026/4/16 14:21:34

Java List 完全指南:从接口特性到四大实现类深度解析

Java List 完全指南:从接口特性到四大实现类深度解析 一、介绍 List 是 Java 集合框架(java.util)中有序、可重复的集合接口,继承自 Collection 接口,是日常开发中最常用的集合类型之一。其核心特征是:元素…

作者头像 李华