九、K8S之Ingress

本文详细介绍了Ingress在Kubernetes中的作用,特别是NginxIngress的配置,包括安装Ingress-nginx控制器,设置镜像源,配置规则创建和路径类型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Ingress

一、Ingress 概念

Ingress提供从集群外部到集群内服务的Http路由,流量路由由 Ingress 资源所定义的规则来控制。通过配置,Ingress可为Service提供外部可访问的URL,对其流量作负载均衡,代理转发。Ingress 的使用可以大大简化应用程序的网络配置和流量路由,并且提供了灵活的路由规则和流量控制功能。

要使用Ingress,需要安装并且配置Ingress控制器。控制器通常是一个负载均衡器,它监听Ingress对象变化,并动态地更新流量路由规则。K8S支持多种Ingress控制器,例如:Nginx、Traefik和HAProxy等。

二、Ingress-nginx概念

为了使得Nginx Ingress资源正常工作,集群中必须要有个Nginx Ingress Controller来解析Nginx Ingress的转发规则。Nginx Ingress Controller收到请求,匹配Nginx Ingress转发规则转发到后端Service所对应的Pod。Kubernetes中Service、Nginx Ingress与Nginx Ingress Controller有着以下关系:

  • Service是后端真实服务的抽象,一个Service可以代表多个相同的后端服务。

  • Nginx Ingress是反向代理规则,用来规定HTTP/HTTPS请求应该被转发到哪个Service所对应的Pod上。例如根据请求中不同的Host和URL路径,让请求落到不同Service所对应的Pod上。

  • Nginx Ingress Controller是一个反向代理程序,负责解析Nginx Ingress的反向代理规则。如果Nginx Ingress有增删改的变动,Nginx Ingress Controller会及时更新自己相应的转发规则,当Nginx Ingress Controller收到请求后就会根据这些规则将请求转发到对应Service的Pod上。

三、安装 Ingress-nginx

3.1、添加仓库源
helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx

helm repo update

# 查看仓库列表
helm repo list

# 搜索 ingress-nginx
helm search repo ingress-nginx


3.2、下载包
# 下载安装包
helm pull ingress-nginx/ingress-nginx

# 解压
tar -zxvf ingress-nginx-4.8.1.tgz
3.3、修改values.yaml文件
  • 修改镜像源信息,并且删除 digest 和digestChroot, 大概在22行左右
  image:
    chroot: false
    registry: registry.cn-hangzhou.aliyuncs.com
    image: google_containers/nginx-ingress-controller
    tag: "v1.5.1"
    
  • 修改hostNetwork 为true,大概在88行
hostNetwork: true
  • 修改 dnsPolicy 的值为 ClusterFirstWithHostNet , 大概在67行
dnsPolicy: ClusterFirstWithHostNet
  • nodeSelector 添加标签: ingress: “true”,用于部署 ingress-controller 到指定节点,大概在287行
  nodeSelector:
    kubernetes.io/os: linux
    ingress: "true"
  • 修改部署类型为DaemonSet, 大概在184行
  kind: DaemonSet
  • 将 admissionWebhooks.enabled 修改为 false , 大概在592行
enabled: false
  • 修改servcie类型,改为NodePort,488行
    type: NodePort
    nodePorts:
      http: "32080"
      https: "32443"
3.4、安装
# 创建命名空间
kubectl create ns ingress-nginx

# 给节点添加标签
kubectl label node k8s-node1 ingress=true

# 执行安装
helm install  ingress-nginx  -n ingress-nginx .

3.5、查看安装是否完成
kubectl get all -n ingress-nginx


查看ingress-nginx下的控制器会有  pod、service和daemonset
------------------------
NAME                
pod/ingress-nginx-controller-swtx4   

NAME
service/ingress-nginx-controller    

NAME
daemonset.apps/ingress-nginx-controller  

四、Ingress 规则创建

4.1、创建示例
apiVersion: networking.k8s.io/v1
kind: Ingress # 资源类型为 Ingress
metadata:
  name: test-ingress
  annotations:
    kubernetes.io/ingress.class: "nginx"
    # 转发重写规则
    nginx.ingress.kubernetes.io/rewrite-target: /
spec:
  rules: # ingress 规则配置,可以配置多个
  - host: shenyao.com # 域名配置,可以使用通配符 *
    http:
      paths: # 相当于 nginx 的 location 配置,可以配置多个
      - pathType: Prefix # 可选:ImplementationSpecific、Exact、Prefix,
        backend:
          service: 
            name: test-svc # 代理到哪个 service
            port: 
              number: 80 # service 的端口
        path: /api # 等价于 nginx 中的 location 的路径前缀匹配
4.2、路径类型

Ingress 的路径匹配规则有三种

  • ImplementationSpecific,对于这种路径类型,匹配方法取决于 IngressClass。 具体实现可以将其作为单独的 pathType 处理或者作与 PrefixExact 类型相同的处理。

  • Exact:精确匹配 URL 路径,且区分大小写。

  • Prefix:基于以 / 分隔的 URL 路径前缀匹配。匹配区分大小写

如果同时满足ExactPrefix,优先Exact类型

4.3、主机名通配符

主机名可以是精确匹配或者通配符来匹配,通配符使用*,例如*.shen.com

主机host 头部匹配与否?
*.foo.combar.foo.com基于相同的后缀匹配
*.foo.combaz.bar.foo.com不匹配,通配符仅覆盖了一个 DNS 标签
*.foo.comfoo.com不匹配,通配符仅覆盖了一个 DNS 标签
### 部署 Ingress Nginx 的方法 在 Kubernetes 集群中部署 Ingress Nginx 是一个常见的任务,以下是详细的方法和步骤[^1]: #### 1. 准备工作 确保 Kubernetes 集群已经正确安装并运行。此外,还需要安装 `kubectl` 并配置好与集群的连接。 #### 2. 下载 Ingress Nginx 的部署文件 访问官方 GitHub 仓库获取最新的部署文件。可以通过以下命令直接下载 YAML 文件: ```bash curl -s https://raw.githubusercontent.com/kubernetes/ingress-nginx/controller-v1.1.0/deploy/static/provider/cloud/deploy.yaml > deploy.yaml ``` 如果网络不通畅,可以手动访问链接并将内容保存为本地文件 `deploy.yaml`[^3]。 #### 3. 修改 DNS 配置(可选) 如果遇到网络问题,例如无法访问 `raw.githubusercontent.com`,可以通过查询其 IP 地址并将其添加到本机的 `hosts` 文件中。例如: ```plaintext 185.199.108.153 raw.githubusercontent.com ``` #### 4. 应用部署文件 使用 `kubectl apply` 命令将 Ingress Nginx 部署到集群中: ```bash kubectl apply -f deploy.yaml ``` #### 5. 验证部署 检查 Ingress Nginx 是否成功部署: ```bash kubectl get pods -n ingress-nginx ``` 输出应显示类似以下内容,表示控制器已成功启动: ```plaintext NAME READY STATUS RESTARTS AGE ingress-nginx-controller-7bdc9d6d8d-xzj2v 1/1 Running 0 1m ``` #### 6. 创建 Ingress 资源 创建一个示例 Ingress 资源文件 `ingress.yml`,内容如下: ```yaml apiVersion: networking.k8s.io/v1 kind: Ingress metadata: name: example-ingress annotations: nginx.ingress.kubernetes.io/rewrite-target: / spec: ingressClassName: nginx rules: - host: www.huazi.com http: paths: - path: /v1 pathType: Prefix backend: service: name: nginx-service port: number: 80 - path: /v2 pathType: Prefix backend: service: name: nginx-service port: number: 80 ``` 应用该资源文件: ```bash kubectl apply -f ingress.yml ``` #### 7. 测试 Ingress 通过浏览器或 `curl` 访问指定域名(如 `www.huazi.com`),验证是否能正确路由到后端服务。 --- ### 注意事项 - 如果使用的是 Minikube 或其他没有外部负载均衡器的环境,可能需要设置 NodePort 或者使用 `minikube tunnel` 来暴露 Ingress 控制器。 - 确保集群中的服务名称和服务端口与 Ingress 资源中的定义一致[^2]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值