Ingress 插件的作用

Ingress 是 Kubernetes 中管理集群外部访问集群内服务的 API 对象,而 minikube 的 ingress 插件为本地开发环境提供了 ingress 功能的支持。

主要作用

1. 实现外部访问

  • 将集群外部的 HTTP/HTTPS 请求路由到集群内部的服务
  • 提供统一的入口点,替代多个 NodePort 或 LoadBalancer 服务

2. 域名路由

# 示例:根据域名路由到不同服务
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: example-ingress
spec:
  rules:
  - host: app1.example.com
    http:
      paths:
      - path: /
        pathType: Prefix
        backend:
          service:
            name: app1-service
            port:
              number: 80
  - host: app2.example.com
    http:
      paths:
      - path: /
        pathType: Prefix
        backend:
          service:
            name: app2-service
            port:
              number: 80

3. 路径路由

# 示例:根据 URL 路径路由到不同服务
spec:
  rules:
  - host: example.com
    http:
      paths:
      - path: /api
        pathType: Prefix
        backend:
          service:
            name: api-service
            port:
              number: 80
      - path: /web
        pathType: Prefix
        backend:
          service:
            name: web-service
            port:
              number: 80

4. SSL/TLS 终止

# 示例:配置 HTTPS
spec:
  tls:
  - hosts:
    - example.com
    secretName: example-tls-secret
  rules:
  - host: example.com
    http:
      paths:
      - path: /
        pathType: Prefix
        backend:
          service:
            name: my-service
            port:
              number: 80

5. 负载均衡

  • 在多个后端服务之间分发流量
  • 支持基于权重的流量分配

启用 minikube ingress 插件

# 启用 ingress 插件
minikube addons enable ingress

# 验证 ingress 插件状态
minikube addons list | grep ingress

# 查看 ingress controller 是否运行
kubectl get pods -n ingress-nginx

实际使用示例

完整示例:部署应用并通过 ingress 访问

# 1. 启用 ingress
minikube addons enable ingress

# 2. 创建 deployment 和 service
cat <<EOF | kubectl apply -f -
apiVersion: apps/v1
kind: Deployment
metadata:
  name: hello-app
spec:
  replicas: 2
  selector:
    matchLabels:
      app: hello
  template:
    metadata:
      labels:
        app: hello
    spec:
      containers:
      - name: hello
        image: nginx
        ports:
        - containerPort: 80
---
apiVersion: v1
kind: Service
metadata:
  name: hello-service
spec:
  selector:
    app: hello
  ports:
  - port: 80
    targetPort: 80
EOF

# 3. 创建 ingress
cat <<EOF | kubectl apply -f -
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: hello-ingress
spec:
  rules:
  - host: hello.minikube.local
    http:
      paths:
      - path: /
        pathType: Prefix
        backend:
          service:
            name: hello-service
            port:
              number: 80
EOF

# 4. 获取 minikube IP
minikube ip

# 5. 添加 hosts 记录(Linux/Mac)
echo "$(minikube ip) hello.minikube.local" | sudo tee -a /etc/hosts

# 6. 测试访问
curl http://hello.minikube.local

与传统方式对比

访问方式 优点 缺点
NodePort 简单直接 需要指定端口,不便于域名管理
LoadBalancer 提供外部 IP 需要云厂商支持,本地环境需模拟
Ingress 域名路由、SSL、统一入口 需要额外部署 controller

适用场景

  1. 本地开发测试:在 minikube 中模拟生产环境的 ingress 行为
  2. 微服务架构:管理多个服务的统一入口
  3. 前后端分离:不同路径路由到不同服务
  4. HTTPS 测试:本地测试 SSL/TLS 配置
  5. 域名测试:模拟多域名环境

注意事项

  • Ingress controller 启动需要 1-2 分钟
  • 修改 hosts 文件才能使用自定义域名访问
  • 生产环境建议使用云厂商的 ingress controller(如 AWS ALB、GCP LoadBalancer)
Logo

欢迎加入DeepSeek 技术社区。在这里,你可以找到志同道合的朋友,共同探索AI技术的奥秘。

更多推荐