Ingress理解

1. 先看最终效果一句话总结

你最后执行的 curl http://www.testingress.com,背后发生的事是:

外部用户通过一个域名(www.testingress.com),直接访问到了集群内部的 Nginx 服务,而不需要知道任何节点 IP、NodePort 或 Service IP。

这就是 Ingress 最核心的价值:用统一的入口,优雅地对外暴露服务


2. 没有 Ingress 之前,你是怎么访问的?

在之前的例子里,你要访问 Nginx 服务,只能用:

  • ClusterIP:80:只能在集群内部访问
  • NodeIP:NodePort:比如 192.168.30.131:30091,端口又长又难记,还依赖节点 IP
  • LoadBalancer IP:比如 192.168.30.240,但每个服务都要占一个 IP,成本高

痛点:每个服务都有自己的访问方式,管理起来一团乱麻。


3. 有了 Ingress 之后,一切变了

Ingress 给你提供了一个统一的 "大门"

  1. 统一入口:所有外部 HTTP/HTTPS 请求,都先打到 Ingress 控制器(Nginx)。
  2. 智能路由 :根据你定义的规则(域名、路径),把流量分发到不同的 Service。
    • www.testingress.comingressservice → Nginx Pod
    • 以后再加个 api.testingress.comapiservice → API Pod,完全没问题
  3. 域名访问:用户只需要记住一个好听的域名,不用管复杂的 IP 和端口。

4. 用你的实验数据,把链路串起来看

我们把你实验里的关键信息串起来,效果就非常清晰了:

  1. 用户输入curl http://www.testingress.com
  2. DNS 解析 :本地 /etc/hostswww.testingress.com 解析到 192.168.30.131(Ingress 控制器所在节点的 IP)
  3. 到达 Ingress 控制器 :请求进入节点 192.168.30.131,被 Nginx Ingress 控制器接收
  4. 匹配规则 :控制器发现请求的 Host 是 www.testingress.com,匹配到你定义的 Ingress 规则
  5. 转发到 Service :控制器把请求转发到 ingressservice(ClusterIP: 10.108.109.255:80
  6. 到达 Pod:Service 再把请求负载均衡到 3 个 Nginx Pod 中的一个

5. Ingress 真正解决的 3 个核心问题

  1. 统一入口:所有服务共享一个 IP / 端口,对外只暴露一个入口。
  2. 域名路由:用域名区分服务,比 IP:Port 友好太多。
  3. 七层能力:支持 HTTP/HTTPS、路径重写、SSL 终结、限流等,这些是 4 层 Service 做不到的。

6. 一句话记忆

Ingress 就是 Kubernetes 集群的 "智能反向代理",帮你把外部流量,按规则分发到内部服务。

相关推荐
梦想很大很大5 小时前
拒绝“盲猜式”调优:在 Go Gin 项目中落地 OpenTelemetry 链路追踪
运维·后端·go
Sinclair6 小时前
内网服务器离线安装 Nginx+PHP+MySQL 的方法
运维
叶落阁主6 小时前
Tailscale 完全指南:从入门到私有 DERP 部署
运维·安全·远程工作
0xDevNull14 小时前
Linux切换JDK版本详细教程
linux
进击的丸子14 小时前
虹软人脸服务器版SDK(Linux/ARM Pro)多线程调用及性能优化
linux·数据库·后端
可观测性用观测云1 天前
云原生网关 Ingress-Nginx 链路追踪实战:OpenTelemetry 采集与观测云集成方案
nginx·kubernetes
甲鱼9291 天前
MySQL 实战手记:日志管理与主从复制搭建全指南
运维
Johny_Zhao2 天前
OpenClaw安装部署教程
linux·人工智能·ai·云计算·系统运维·openclaw
蝎子莱莱爱打怪3 天前
GitLab CI/CD + Docker Registry + K8s 部署完整实战指南
后端·docker·kubernetes
chlk1234 天前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统