news 2025/12/25 14:35:36

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进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/19 6:08:17

Node.js性能优化终极实战:从单核瓶颈到多核巅峰的完整指南

Node.js性能优化终极实战:从单核瓶颈到多核巅峰的完整指南 【免费下载链接】node-interview How to pass the Node.js interview of ElemeFE. 项目地址: https://gitcode.com/gh_mirrors/no/node-interview Node.js性能优化是每个后端开发者必须掌握的技能。…

作者头像 李华
网站建设 2025/12/16 10:39:07

Directus:颠覆传统,零成本打造企业级数据管理平台

Directus:颠覆传统,零成本打造企业级数据管理平台 【免费下载链接】directus Directus 是一个开源的、实时的内容管理平台,用于构建可扩展的数据管理应用程序。* 管理和操作数据库数据;支持多种数据库类型;支持自定义字…

作者头像 李华
网站建设 2025/12/16 10:39:00

实现精准比率式检测:钠离子荧光探针SoNa 520的特性

钠离子荧光探针 SoNa 520是一款非常优秀的、用于检测细胞内钠离子(Na⁺)浓度的重要工具,在现代生命科学研究,特别是神经科学和心血管生理学领域应用广泛。一、钠离子荧光探针 SoNa 520参数Ex(nm) 491Em(nm) 511溶剂 DMSO存储条…

作者头像 李华
网站建设 2025/12/16 10:37:11

30分钟掌握POCO C++库:构建跨平台网络应用

30分钟掌握POCO C库:构建跨平台网络应用 【免费下载链接】poco The POCO C Libraries are powerful cross-platform C libraries for building network- and internet-based applications that run on desktop, server, mobile, IoT, and embedded systems. 项目地…

作者头像 李华
网站建设 2025/12/16 10:36:29

终极指南:如何用Pintr将照片快速转化为专业线条画

终极指南:如何用Pintr将照片快速转化为专业线条画 【免费下载链接】pintr Create single line illustrations from your pictures. Get a drawing, SVG or coordinates for a CNC. 项目地址: https://gitcode.com/gh_mirrors/pi/pintr 你是否曾经想要将普通照…

作者头像 李华
网站建设 2025/12/16 10:36:10

Linux内核实时调度:如何选择最适合你的调度策略?[特殊字符]

Linux内核实时调度:如何选择最适合你的调度策略?🤔 【免费下载链接】linux-insides-zh Linux 内核揭秘 项目地址: https://gitcode.com/gh_mirrors/li/linux-insides-zh 在嵌入式开发、工业自动化等高实时性要求的场景中,你…

作者头像 李华