标签:name ip 端口 nginx 集群 NodePort pod K8s
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
curl 192.168.222.250:80/index.html
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
kubectl apply -f Node_pod.yaml
访问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 需要负载均衡器的 支持,一般云服务商都有提供
标签:name,ip,端口,nginx,集群,NodePort,pod,K8s 来源: https://blog.51cto.com/sdsca/2422193
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。