在K8S中,Pod网络访问与Docker容器端口映射有何不同?

简介: 在K8S中,Pod网络访问与Docker容器端口映射有何不同?

在Kubernetes和Docker原生端口映射之间,主要区别在于:

1.Docker原生端口映射

  • Docker容器在启动时可以通过 -p 参数指定宿主机端口到容器内部端口的映射,例如:docker run -p 8080:80 nginx,这意味着外部通过宿主机的8080端口可以访问到容器内运行的nginx服务的80端口。
  • Docker使用NAT技术在宿主机上创建端口转发规则,使得来自宿主机外部的流量能够到达正确的容器内部服务。

2.Kubernetes中的Pod网络

  • 在Kubernetes中,Pod有自己的IP地址,它们可以直接通过集群内部的服务发现机制互相访问,而无需显式端口映射。
  • 对于集群外部的访问,通常不直接对Pod进行端口映射,而是创建一个Service资源,并定义其类型(如ClusterIP、NodePort或LoadBalancer)来暴露Pod内的服务。
  • ClusterIP 类型的Service会为Pod分配一个仅集群内部可访问的虚拟IP地址和端口。
  • NodePort 类型的Service会自动在每个节点上打开一个特定端口,允许从集群外部通过这个端口访问到Pod。
  • LoadBalancer 类型的Service在支持的云环境中,会进一步配置一个外部负载均衡器将流量引入集群。

因此,区别在于:

  1. Docker端口映射是单机环境下的简单一对一映射,主要用于将外部请求路由到特定容器。
  2. Kubernetes则提供了一种更复杂的网络模型,包括内部服务发现、多层抽象以及灵活的端口和服务管理,它不依赖于宿主机级别的端口映射,而是通过网络插件实现跨节点的Pod间通信和对外服务的统一入口。

综上所述,在Kubernetes中,端口映射更为复杂且灵活,涉及到服务发现、网络策略以及多层抽象。而Docker中的端口映射更偏向于一对一的简单宿主机与容器间的网络通信。在Kubernetes中,Pod并不直接对外提供端口映射,而是由Service来管理并提供对一组Pod实例的访问入口。


相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
3月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
724 108
|
26天前
|
网络协议 Linux 虚拟化
配置VM网络:如何设定静态IP以访问主机IP和互联网
以上就是设定虚拟机网络和静态IP地址的基本步骤。需要注意的是,这些步骤可能会因为虚拟机软件、操作系统以及网络环境的不同而有所差异。在进行设定时,应根据具体情况进行调整。
237 10
|
1月前
|
监控 Kubernetes 安全
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
|
1月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
287 5
|
1月前
|
监控 Linux 调度
【赵渝强老师】Docker容器的资源管理机制
本文介绍了Linux CGroup技术及其在Docker资源管理中的应用。通过实例演示了如何利用CGroup限制应用程序的CPU、内存和I/O带宽使用,实现系统资源的精细化控制,帮助理解Docker底层资源限制机制。
145 6
|
2月前
|
Shell 开发工具 git
使用代理访问网络各项命令总结
工作中常需设置代理,容易导致环境混乱。本文总结了 SourceTree 无法拉取代码的问题,排查了环境变量、Git 全局配置及系统代理设置,最终通过清除 Git 代理配置解决。内容涵盖排查步骤、命令整理及脚本处理,帮助快速定位并解决代理相关网络问题。
138 2
|
3月前
|
缓存 Ubuntu Docker
Ubuntu环境下删除Docker镜像与容器、配置静态IP地址教程。
如果遇见问题或者想回滚改动, 可以重启系统.
256 16

推荐镜像

更多