Ingress典型配置

Ingress 是 Kubernetes 中用于管理 HTTP 和 HTTPS 路由的资源。以下是一个典型的 Ingress 配置示例,用于将流量引导到两个不同的服务:

bash 复制代码
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: example-ingress
spec:
  rules:
    - host: example.com
      http:
        paths:
          - path: /app1
            pathType: Prefix
            backend:
              service:
                name: app1-service
                port:
                  number: 80
          - path: /app2
            pathType: Prefix
            backend:
              service:
                name: app2-service
                port:
                  number: 80
  tls:
    - hosts:
        - example.com
      secretName: example-tls-secret
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: example-ingress
spec:
  rules:
    - host: example.com
      http:
        paths:
          - path: /app1
            pathType: Prefix
            backend:
              service:
                name: app1-service
                port:
                  number: 80
          - path: /app2
            pathType: Prefix
            backend:
              service:
                name: app2-service
                port:
                  number: 80
  tls:
    - hosts:
        - example.com
      secretName: example-tls-secret

在这个示例中:

  • apiVersion 指定了 Ingress 资源的 API 版本。
  • kind 表示资源类型,这里是 Ingress。
  • metadata 部分包含了 Ingress 的名称。
  • spec 部分定义了 Ingress 的规则和 TLS 配置。

在规则部分:

  • host 指定了要路由的主机名,这里是 example.com
  • http 定义了 HTTP 路由规则。
  • paths 包含了路径规则,它们将请求路由到不同的后端服务。
  • path 指定了路径的前缀,例如 /app1/app2
  • pathType 设置为 Prefix 表示使用前缀匹配。
  • backend 定义了后端服务的名称(app1-serviceapp2-service)以及端口号。

在 TLS 部分:

  • hosts 列出了要启用 TLS 的主机名,这里是 example.com
  • secretName 是用于 TLS 加密的证书密钥对的名称,这个密钥对需要事先创建并存储在 Kubernetes Secret 中。

这个 Ingress 配置示例将流量路由到两个不同的后端服务 app1-serviceapp2-service,基于请求的路径前缀。同时,它启用了 TLS 加密以确保安全的通信。

请注意,要使此配置生效,你需要在你的 Kubernetes 集群中部署和配置一个 Ingress Controller,以确保它能够理解和处理 Ingress 资源。不同的 Ingress Controller 可能有略微不同的配置方式,因此你需要参考特定 Ingress Controller 的文档来进行部署和配置。

相关推荐
@ chen10 小时前
kubectl常用命令
云原生·kubernetes·k8s
博客园团队1 天前
博客园出海记-组装集装箱:自建 Kubernetes 集群
k8s·出海记
虚伪的空想家1 天前
K8S的dashboard部署与访问
云原生·容器·kubernetes·k8s·web·dashboard
一个向上的运维者2 天前
详细解读k8s的kind中service与pod的区别
容器·k8s
感哥2 天前
Kubernetes Pod
k8s
空灵之海3 天前
Ubuntu系统安全合规配置
linux·ubuntu·系统安全·1024程序员节
Elastic 中国社区官方博客3 天前
使用 cloud-native Elasticsearch 与 ECK 运行
大数据·数据库·elasticsearch·搜索引擎·kubernetes·k8s·全文检索
岚天start4 天前
K8s Ingress Annotations参数使用指南
nginx·kubernetes·k8s·ingress·ingress控制器
岚天start4 天前
在公用同一公网IP和端口的K8S环境中,不同域名实现不同访问需求的解决方案
kubernetes·k8s·白名单·访问控制·ingress·ingress控制器·annotations
方渐鸿5 天前
【2024】k8s集群 图文详细 部署安装使用(两万字)
java·运维·容器·kubernetes·k8s·运维开发·持续部署