k8s暴露服务NodePort

NodePort暴露服务:

即要在浏览器访问k8s内的pod内的docker容器服务应用,如果使用NodePort类型暴露服务,需要在k8s空运行产生的yml文件中指定type类型是NodePort。具体暴露在浏览器的端口可以指定可以不指定,如果指定就要指定nodePort:3万以上端口。在浏览器访问k8s中的pod中docker容器时就可用指定的nodePort中的端口进行访问,或者不指定端口那k8s就会随机选择一个3万以上的端口进行服务暴露。即使用节点IP:暴露端口就可以访问k8s中pod的中的docker应用。可以通过kubectl expose deployment 控制器名称 --port=容器内部端口 --target-port=容器对外暴露端口--type=NodePort(即浏览器访问容器使用的端口暴露类型)--node-port=3万以上端口(NodePort类型暴露服务指定的端口,也可不写,就用k8s的随机的3万以上的端口就行)

缺点:

因为IP地址可能经常发生变化等原因,生产环境不推荐使用,可以用于临时演示

K8S暴露服务的三种端口说明:

nodePort:外部即浏览器访问k8s中的pod中的docker容器的端口

targetPort:dockerfile中的expose暴露的端口,即k8s中的pod中的docker容器应用对外暴露的端口

port:k8s集群内docker容器之间互相访问的端口

注意:docker容器在启动时各个容器有一个端口即port,然后有一个对外暴露的端口即targetPort,在运行时可以通过-p命令进行端口映射或者通过dockerfile文件中的expose命令进行外部端口暴露,容器内部互相访问用port,如果容器没有放在k8s的pod内,那么也是可以通过浏览器访问docker容器对外暴露的端口去访问docker容器,如果容器放在了k8s的pod内,那么要通过浏览器访问k8s中的Pod中的docker容器就必须要添加nodePort端口,只添加targetPort和port是不能进行浏览器访问的

个人理解。。。。不知道有没有问题。。。。。。

相关推荐
熊猫钓鱼>_>2 小时前
最方便的应用构建——利用云原生快速搭建本地deepseek知识仓库
云原生·知识图谱·云开发·hai·codebuddy·云应用·cnb
回忆是昨天里的海2 小时前
docker自定义网络-简单总结
运维·docker·容器
iconball3 小时前
个人用云计算学习笔记 --32 Docker和docker swarm
运维·笔记·学习·docker·容器·云计算
摇滚侠3 小时前
镜像容器相关命令,docker export/import/save/load/commit,导出容器给别人使用
运维·docker·容器
逸巽散人4 小时前
云边协同:基于 Docker 与 FRP 的家庭实验室全栈内网穿透指南
云原生·eureka
回忆是昨天里的海4 小时前
docker Compose-安装wordpress
运维·docker·容器
木二_4 小时前
附057.RustFS云原生Kubernetes部署指南
云原生·kubernetes·云原生存储·对象存储·分布式存储·rustfs
孤岛悬城4 小时前
47 Dockerfile场景化:公司内网业务上线(分角色/分模块)
docker·容器·云计算
无泪无花月隐星沉5 小时前
续写云计算的前世今生
kubernetes·云计算·openstack