DeepSeek Ingress 插件的作用
Ingress 是 Kubernetes 中管理集群外部访问集群内服务的 API 对象,而。为本地开发环境提供了 ingress 功能的支持。
·
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 |
适用场景
- 本地开发测试:在 minikube 中模拟生产环境的 ingress 行为
- 微服务架构:管理多个服务的统一入口
- 前后端分离:不同路径路由到不同服务
- HTTPS 测试:本地测试 SSL/TLS 配置
- 域名测试:模拟多域名环境
注意事项
- Ingress controller 启动需要 1-2 分钟
- 修改 hosts 文件才能使用自定义域名访问
- 生产环境建议使用云厂商的 ingress controller(如 AWS ALB、GCP LoadBalancer)
更多推荐




所有评论(0)