云计算核心技术Docker教程:容器访问控制

发布时间:2025-11-06 点击:1
容器的访问控制,主要通过 linux 上的 iptables 防火墙来进行管理和实现。iptables 是 linux 上默认的防火墙软件,在大部分发行版中都自带。
容器访问外部网络
容器要想访问外部网络,需要本地系统的转发支持。在linux 系统中,检查转发是否打开。
$sysctl net.ipv4.ip_forward
net.ipv4.ip_forward = 1
如果为 0,说明没有开启转发,则需要手动打开。
$sysctl -w net.ipv4.ip_forward=1
如果在启动 docker 服务的时候设定 –ip-forward=true, docker 就会自动设定系统的 ip_forward 参数为 1。
容器之间访问
容器之间相互访问,需要两方面的支持。
容器的网络拓扑是否已经互联。默认情况下,所有容器都会被连接到 docker0 网桥上。
本地系统的防火墙软件 — iptables 是否允许通过。
访问所有端口
当启动 docker 服务时候,默认会添加一条转发策略到 iptables 的 forward 链上。策略为通过(accept)还是禁止(drop)取决于配置–icc=true(缺省值)还是 –icc=false。当然,如果手动指定 –iptables=false 则不会添加 iptables 规则。
可见,默认情况下,不同容器之间是允许网络互通的。如果为了安全考虑,可以在 /etc/default/docker 文件中配置 docker_opts=–icc=false 来禁止它。
访问指定端口
在通过 -icc=false 关闭网络访问后,还可以通过 –link=container_name:alias 选项来访问容器的开放端口。
例如,在启动 docker 服务时,可以同时使用 icc=false –iptables=true 参数来关闭允许相互的网络访问,并让docker 可以修改系统中的 iptables 规则。
之后,启动容器(docker run)时使用 –link=container_name:alias 选项,docker 会在 iptable 中为 两个容器分别添加一条 accept 规则,允许相互访问开放的端口(取决于 dockerfile 中的 expose 行)。

爆款云服务器在那领券
阿里云服务器购买步骤流程
服务器异常
哪些行业适合租云服务器
作为一个合格的域名抢注者,易名这个工具你知道吗?
阿里云服务器便宜购买教程
php如何实现ios推送
租用服务器好还是放云平台好