首页 > 其他分享 >在K8S中,K8S外部节点访问Pod有哪些方式?

在K8S中,K8S外部节点访问Pod有哪些方式?

时间:2024-08-12 19:07:22浏览次数:14  
标签:name Service 宿主机 端口 influxdb Pod K8S 节点

在Kubernetes(K8S)中,外部节点访问Pod的方式主要有以下几种:

1. hostNetwork
  • 原理:通过将Pod配置为使用hostNetwork,Pod中的容器将直接看到并共享宿主机的网络接口。这意味着外部流量可以直接通过宿主机的IP地址和端口访问Pod内的服务。

  • 配置示例:

    apiVersion: v1  
    kind: Pod  
    metadata:  
      name: influxdb  
    spec:  
      hostNetwork: true  
      containers:  
      - name: influxdb  
        image: influxdb
    
  • 注意事项:

    • Pod的IP地址会随着Pod的重新调度而改变,因此使用hostNetwork时需要考虑IP地址的变化。
    • 需要确保宿主机上的端口不被其他服务占用,以避免端口冲突。
    • 此方式适用于需要直接控制宿主机网络或需要特定端口映射的场景。
2. hostPort
  • 原理:通过将Pod的容器端口直接映射到宿主机的端口上,外部流量可以通过宿主机的IP地址和映射的端口访问Pod内的服务。

  • 配置示例:

    apiVersion: v1  
    kind: Pod  
    metadata:  
      name: influxdb  
    spec:  
      containers:  
      - name: influxdb  
        image: influxdb  
        ports:  
        - containerPort: 8086  
          hostPort: 8086
    
  • 注意事项:

    • 与hostNetwork类似,Pod的调度可能导致宿主机和端口的变化,需要管理Pod与宿主机的对应关系。
    • 此方式适用于需要固定端口映射的场景,但不建议在生产环境中广泛使用,因为它限制了Pod的灵活性和可扩展性。
3. NodePort
  • 原理:通过将Service的类型设置为NodePort,Kubernetes会在每个节点上分配一个静态端口(范围通常为30000-32767),并将该端口上的流量转发到Service背后的Pod。

  • 配置示例:

    apiVersion: v1  
    kind: Service  
    metadata:  
      name: influxdb  
    spec:  
      type: NodePort  
      ports:  
      - port: 8086  
        nodePort: 30000  
      selector:  
        name: influxdb
    
  • 访问方式:使用集群中任意节点的IP地址加上NodePort端口号(如<NodeIP>:30000)来访问Service。

  • 注意事项:

    • NodePort提供了集群外部访问Pod的简便方式,但会占用集群节点的端口资源。
    • 如果集群规模较大,NodePort端口的管理可能会变得复杂。
4. LoadBalancer
  • 原理:在NodePort的基础上,通过云提供商的负载均衡器将外部流量分发到集群节点的NodePort上,再由kube-proxy转发到Service背后的Pod。

  • 配置示例

    (以AWS为例):

    apiVersion: v1  
    kind: Service  
    metadata:  
      name: influxdb  
    spec:  
      type: LoadBalancer  
      ports:  
      - port: 8086  
        targetPort: 8086  
      selector:  
        name: influxdb
    
  • 访问方式:使用云提供商提供的负载均衡器的IP地址和端口来访问Service。

  • 注意事项:

    • LoadBalancer类型的Service只能在支持云提供商负载均衡器的环境中使用。
    • 需要支付云提供商的负载均衡器费用。
5. Ingress
  • 原理:Ingress是Kubernetes的一个API对象,它定义了进入集群的规则,允许将HTTP和HTTPS流量路由到集群内的Service。Ingress控制器(如Nginx Ingress Controller)根据Ingress资源中的规则配置负载均衡器,并将流量转发到相应的Service。

  • 配置示例:

    apiVersion: networking.k8s.io/v1  
    kind: Ingress  
    metadata:  
      name: influxdb  
    spec:  
      rules:  
      - host: influxdb.example.com  
        http:  
          paths:  
          - path: /  
            pathType: Prefix  
            backend:  
              service:  
                name: influxdb  
                port:  
                  number: 8086
    
  • 访问方式:通过配置的域名(如influxdb.example.com)访问Service。

  • 注意事项:

    • Ingress提供了更灵活的路由和负载均衡能力,但需要部署Ingress控制器。
    • Ingress控制器通常部署在集群内部,但可以通过NodePort或LoadBalancer等方式暴露给外部访问

标签:name,Service,宿主机,端口,influxdb,Pod,K8S,节点
From: https://www.cnblogs.com/huangjiabobk/p/18355567

相关文章

  • 在K8S中,影响Pod调度策略的有哪些?
    在Kubernetes(K8S)中,影响Pod调度策略的因素众多,这些因素共同决定了Pod最终将被调度到哪个节点上运行。以下是影响Pod调度策略的主要因素:1.资源请求与限额资源请求(Requests):Pod在创建时会声明需要的最小资源量,如CPU和内存。调度器会寻找至少能满足这些资源请求的Node进行调度。资......
  • kubernetes记录一起因为磁盘容量不足造成pod无线驱逐pod状态为Evicted
    线上的pod遭到无线的驱逐fxxx-xxxx-deploy-86684b76ff-2vkdx0/1Evicted030m<none>10.10.10.10<none><none>fxxx-xxxx-deploy-86684b76ff-5j6fd0/1Evicted030m<none&......
  • k8s技术总结(一)
    在学习完docker之后,也很有必要再学习k8s的一些理论和技术。一、基础概念kubernetes(k8s)和docker在容器管理领域具有不同的侧重点和优势。当前docker主要关注单个容器的构建、运行和管理,而k8s则专注于大规模的容器编排和管理。k8s在以下几个特性中,更具有优势。特性1:自动化部署和......
  • Kubernetes-Init容器与静态Pod
    目录Init容器什么是Init容器?理解init容器Init容器与普通容器的不同之处静态Pod通过配置文件创建Init容器在Pod的生命周期中,可以执行多种操作如下图:什么是Init容器?Init容器也就是我们平时常说的初始化容器。InitContainer就是用来做初始化工作的容器,可以是一个或者多个,如果有......
  • 【WSN覆盖优化】基于鱼鹰优化算法OOA求解无线传感器节点2D覆盖优化问题附Matlab代码
    鱼鹰优化算法(OspreyOptimizationAlgorithm,OOA)是一种基于鱼鹰捕鱼行为的启发式优化算法,可用于解决优化问题。在无线传感器网络(WSN)中,覆盖优化是一个关键问题,涉及到最大化网络覆盖范围并减少节点数量。以下是一个简单的示例框架,展示如何基于OOA算法求解无线传感器节点的二......
  • kubernetes-POD的基本原理
    目录什么是POD?POD有以下特点:为什么使用POD作为最小单元,而不是container为什么允许一个POD里有多个容器POD中如何管理多个容器POD的yaml格式定义配置文件说明如何使用PodPOD的持久性和终止Pause我们首先在节点上运行一个pause容器然后再运行一个nginx容器,nginx将为localhost:2368......
  • 【WSN覆盖优化】基于斑马优化算法ZOA求解无线传感器节点2D覆盖优化问题附Matlab代码
    以下是一个简单的示例Matlab代码,演示如何使用斑马优化算法(ZebraOptimizationAlgorithm,ZOA)来解决无线传感器节点(WSN)的2D覆盖优化问题:ini复制%ZebraOptimizationAlgorithm(ZOA)forWirelessSensorNetwork(WSN)CoverageOptimization%设置参数num_nodes=50;......
  • CertBot搭配DNSPod
    CertBot搭配DNSPodsummary:cetbot搭配dnspod实现自动注册ssl证书和自动续期......
  • ComfyUI插件:ComfyUI layer style 节点(一)
    ComfyUI插件:ComfyUIlayerstyle节点(一)前言:学习ComfyUI是一场持久战,而ComfyUIlayerstyle是一组专为图片设计制作且集成了Photoshop功能的强大节点。该节点几乎将PhotoShop的全部功能迁移到ComfyUI,诸如提供仿照AdobePhotoshop的图层样式、提供调整颜色功能(亮度、饱和度、......