Kubernetes的Ingress 资源是什么?

在Kubernetes中,Ingress资源是一种用于管理集群外部对内部服务访问的API对象,主要用于将不同的外部请求路由到集群内的不同服务,以下是关于它的详细介绍:

定义与作用

  • Ingress资源定义了从集群外部到内部服务的HTTP和HTTPS路由规则。通过Ingress,可以将多个不同域名或不同路径的请求,根据定义的规则,导向到集群内不同的Kubernetes服务,从而实现对集群内服务的统一外部访问管理。

核心组成部分

  • 规则(Rules) :是Ingress资源的核心部分,用于定义具体的路由规则。每个规则可以包含一个主机名(Host)和一个或多个路径(Path)及相关的后端服务配置。例如,可以定义一个规则,当请求的主机名为example.com且路径为/app1时,将请求转发到名为service1的Kubernetes服务。
  • 后端(Backends) :指定了在满足规则条件时,请求应该被路由到的目标服务和端口。一个后端通常由服务名称和端口号组成,例如service1:8080,表示将请求发送到名为service1的服务的8080端口。
  • TLS配置:用于配置Ingress资源的传输层安全(TLS)设置,以确保通信的安全性。可以指定SSL/TLS证书和密钥,用于对通过Ingress的HTTPS流量进行加密和解密。

示例

以下是一个简单的Ingress资源的YAML示例:

yaml 复制代码
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: service1
            port:
              number: 8080
      - path: /app2
        pathType: Prefix
        backend:
          service:
            name: service2
            port:
              number: 80

在这个示例中,定义了一个名为example-ingress的Ingress资源。它包含一个规则,当请求的主机名为example.com时,根据不同的路径进行路由。如果路径以/app1开头,请求将被路由到service1的8080端口;如果路径以/app2开头,请求将被路由到service2的80端口。

相关推荐
Johny_Zhao1 小时前
Docker + CentOS 部署 Zookeeper 集群 + Kubernetes Operator 自动化运维方案
linux·网络安全·docker·信息安全·zookeeper·kubernetes·云计算·系统运维
代码老y4 小时前
Docker:容器化技术的基石与实践指南
运维·docker·容器
掘金-我是哪吒8 小时前
分布式微服务系统架构第156集:JavaPlus技术文档平台日更-Java线程池使用指南
java·分布式·微服务·云原生·架构
阿里云云原生9 小时前
Serverless JManus: 企业生产级通用智能体运行时
云原生
Kookoos13 小时前
ABP VNext + Tye:本地微服务编排与调试
微服务·云原生·架构·tye
掘金-我是哪吒18 小时前
分布式微服务系统架构第157集:JavaPlus技术文档平台日更-Java多线程编程技巧
java·分布式·微服务·云原生·架构
掘金-我是哪吒19 小时前
分布式微服务系统架构第155集:JavaPlus技术文档平台日更-Java线程池实现原理
java·分布式·微服务·云原生·架构
朱杰jjj19 小时前
Docker容器中无法使用vim、vi命令处理
docker·容器·vim
东林牧之19 小时前
CICD[软件安装]:docker安装gitlab
docker·容器·gitlab
cui_hao_nan1 天前
Docker后端部署
运维·docker·容器