K8s 集群pod 的几种访问模式

k8s 访问pod 和service 主要有以下几种方式

  • hostNetwork
  • hostPort
  • NodePort
  • LoadBalancer
  • Ingress

hostNetwork 主机网络模式 ,相当于 docker run --net=host

示例演示

apiVersion: v1
kind: Pod
metadata:
  name: nginx-host
spec:
  hostNetwork: true
  containers:
    - name: nginx-host
      image: nginx
 kubectl create -f hostNetwork.yaml

查看pod 的ip 为 node 节点的ip,选择这种网络模式 pod 调度 ,pod 会根据节点选择不同的node ip 发生变化,port 端口,需要保持不与宿主机上的port 端口发生冲突。

hostport 模式

hostPort是直接将容器的端口与所调度的节点上的端口路由,这样用户就可以通过宿主机的IP加上来访问Pod了

示例演示

apiVersion: v1
kind: Pod
metadata:
  name: nginx-port
spec:
  hostNetwork: true
  containers:
    - name: nginx-host
      image: nginx
      ports: 
        - containerPort: 80
          hostPort: 80

kubectl create -f hostPort.yaml

pod 被调度不同节点,ip 就会发生变化,需要维护pod 与宿主机间的对应关系

NodePort 模式

NodePort 模式 k8s service 默认情况使用 cluster IP 的方式, 这样service 就会产生一个Cluster IP 的模式,这个cluster ip 默认只能在集群内部访问,想要在外部直接访问 service ,需要将 service type 的类型修改为 nodePort 模式 , nodePort值,范围是30000-32767

示例如下

apiVersion: v1
kind: Pod
metadata:
  name: nginx
  labels:
    name: nginx
spec:
  containers:
    - name: nginx
      image: nginx
      ports:
        - containerPort: 80
---
kind: Service
apiVersion: v1
metadata:
  name: nginx
spec:
  type: NodePort
  ports: 
    - port: 80
      nodePort: 30008  #  nodePort值,范围是30000-32767
  selector:
    name: nginx

访问pod 的三种方式

集群内部访问

pod ip :curl 10.244.1.245

ClusterIP :curl 10.1.250.193

集群外部访问

NodePort: master:

http://192.168.222.240:30008

使用 NodePort 模式会在 master 和node 节点上新开一个端口 ,使用多个NodePort 模式需要维护好 端口的对应关系,防止出现端口冲突

LoadBalancer 需要负载均衡器的 支持,一般云服务商都有提供

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值