kubernetes之Ingress

一、背景

Ingress是k8s中实现7层负载的实现方式,是公开集群外部流量到集群内服务的HTTP和HTTPS路由

二、Ingress基础

通常Ingress实现由Ingress 控制器和Ingress组成,Ingress控制器负责具体实现反向代理及负载均衡,Ingress负责定义匹配规则和路由

Ingress-nginx控制器部署参见:Installation Guide - Ingress-Nginx Controller

Ingress流程示意图:

三、示例

复制代码
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: minimal-ingress
  annotations:
    nginx.ingress.kubernetes.io/rewrite-target: /
spec:
  ingressClassName: nginx-example
  rules:
  - http:
      paths:
      - path: /testpath
        pathType: Prefix
        backend:
          service:
            name: test
            port:
              number: 80

参数解释说明:

  1. ingressClassName: 指定Ingressclass名称,集群可以有多个class

  2. rules:规则具体定义

  3. paths:指定匹配URI

  4. backend: 指定匹配到URI后转发到后端的service

  5. annotations: 配合Ingress控制器来配置;不同的控制器,这里注解不一样

其他参数:

host:未指定host,则规则适用于通过指定IP地址的所有入站流量;反之,则只是适用于特定的host

backend: service加端口的组合;

defaultBackend:默认后端,通常在Ingress控制器配置,实现无法和rules匹配的其他路由处理

四、路径类型

pathType有如下选项:

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

  2. Prefix:基于/分隔的URL路径前缀匹配,区分大小写

  3. ImplementationSpecific:对于这种路径类型,匹配方法取决于 IngressClass

五、Ingress类

Ingress可以有不同的控制器,通常也使用不同的配置;每个Ingress应当改指定一个类,也就是对ingressClass资源的引用

复制代码
apiVersion: networking.k8s.io/v1
kind: IngressClass
metadata:
  name: external-lb
spec:
  controller: example.com/ingress-controller
  parameters:
    apiGroup: k8s.example.com
    kind: IngressParameters
    name: external-lb
相关推荐
想进部的张同学33 分钟前
RK3588开发板安装GStreamer硬件加速插件完整指南 成功版本(docker)
运维·docker·容器·rkmpp
涟漪海洋1 小时前
docker启动容器覆盖镜像中的命令
运维·docker·容器
2501_948120151 小时前
云原生应用的安全开发与防护策略
安全·云原生
ZIXEL子虔科技1 小时前
从本地到云端:三维 CAD 国产化的下一步在哪里
ai·云原生
jiayong233 小时前
Kubernetes 网络与服务发现面试题详解
网络·kubernetes·服务发现
噎住佩奇3 小时前
k8s创建测试Pod的流程
云原生·容器·kubernetes
ζั͡山 ั͡有扶苏 ั͡✾3 小时前
从Rancher崩溃中恢复Kubernetes集群访问权限:完整kubeconfig恢复指南
容器·kubernetes·rancher
無限神樂4 小时前
docker compose简介
运维·docker·容器
Lim小刘4 小时前
深度实践:从“手动排障”到“对话诊断”,构建基于 GenAI 的 K8s 智能运维平台
云原生·容器·kubernetes
rustfs4 小时前
如何将 Minio DirectPV 配置为 RustFS 存储后端?
分布式·docker·云原生·rust