后浪云Docker教程:Docker容器访问控制

树叶云

容器的访问控制,主要通过 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 规则。

此时,系统中的 iptables 规则可能是类似

$ sudo iptables -nL
...
Chain FORWARD (policy ACCEPT)
target     prot opt source               destination
DROP       all  --  0.0.0.0/0            0.0.0.0/0
...

之后,启动容器(docker run)时使用 --link=CONTAINER_NAME:ALIAS 选项。Docker 会在 iptable 中为 两个容器分别添加一条 ACCEPT 规则,允许相互访问开放的端口(取决于 Dockerfile 中的 EXPOSE 行)。

当添加了 --link=CONTAINER_NAME:ALIAS 选项后,添加了 iptables 规则。

$ sudo iptables -nL
...
Chain FORWARD (policy ACCEPT)
target     prot opt source               destination
ACCEPT     tcp  --  172.17.0.2           172.17.0.3           tcp spt:80
ACCEPT     tcp  --  172.17.0.3           172.17.0.2           tcp dpt:80
DROP       all  --  0.0.0.0/0            0.0.0.0/0

注意:--link=CONTAINER_NAME:ALIAS 中的 CONTAINER_NAME 目前必须是 Docker 分配的名字,或使用 --name 参数指定的名字。主机名则不会被识别。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/191935.html<

(0)
运维的头像运维
上一篇2025-04-01 08:49
下一篇 2025-04-01 08:51

相关推荐

  • 使用Docker安装Fluentd的教程

    使用Docker安装Fluentd的教程 Fluentd是一款开源的数据收集器,能够帮助用户统一数据收集和处理。它支持多种数据源和数据输出,广泛应用于日志管理和数据分析。使用Doc…

  • 使用Docker安装RabbitMQ的教程

    使用Docker安装RabbitMQ的教程 RabbitMQ是一款流行的开源消息代理软件,广泛应用于分布式系统中,用于实现异步消息传递。使用Docker来安装RabbitMQ可以简…

  • 使用Docker安装Kafka的教程

    使用Docker安装Kafka的教程 Apache Kafka 是一个分布式流处理平台,广泛用于构建实时数据管道和流应用程序。使用 Docker 安装 Kafka 可以简化部署过程…

  • 使用Docker安装Celery的教程

    使用Docker安装Celery的教程 Celery是一个强大的异步任务队列/作业队列,基于分布式消息传递。它被广泛用于处理后台任务,尤其是在需要处理大量数据或执行长时间运行的任务…

  • 使用Docker安装PHP的教程

    使用Docker安装PHP的教程 在现代软件开发中,Docker已经成为一种流行的容器化技术。它允许开发者将应用程序及其依赖项打包到一个轻量级的容器中,从而确保在不同环境中都能一致…

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注