Docker笔记9 | Docker中网络功能知识梳理和了解
9 | Docker中网络功能知识梳理和了解
简单说:Docker 允许通过外部访问容器或容器互联的方式来提供网络服务。
1 外部访问容器
1.1 访问方式
- 要想让外部访问容器中的一些网络应用,需要通过
-P或-p参数来指定端口映
射; -P:Docker会随机映射一个端口到内部容器开放的网络端口;docker container ls查看到本地主机的 32768 被映射到了容器的 80 端口,此时访问本机的
32768 端口即可访问容器内NGINX默认页面:

docker run -d -P nginx:alpine:

-p:指定要映射的端口(在一个指定端口上只可以绑定一个容器)。
# 支持的格式
ip:hostPort:containerPort | ip::containerPort | hostPort:containerPort
1.2 映射所有接口地址
- 方式:
hostPort:containerPort(默认会绑定本地所有接口上的所有地址); - 举例:本地的80映射到容器的80端口:
docker run -d -p 80:80 nginx:alpine

1.3 映射到指定地址的指定端口
- 方式:
ip:hostPort:containerPort(指定映射使用一个特定地址); - 举例:比如
localhost地址:
docker run -d -p 127.0.0.1:80:80 nginx:alpine
- 我这里端口已经被绑定了,所以会报错,先不管这个:

1.4 映射到指定地址的任意端口
- 方式:
ip::containerPort; - 举例:绑定
localhost的任意端口到容器的 80 端口,本地主机会自动分配一个端口:
docker run -d -p 127.0.0.1::80 nginx:alpine

1.5 查看映射端口配置
- 命令:
docker port;

2 容器互联
2.1 新建网络
- 创建新的docker网络:
docker network create -d bridge mynet

2.2 连接容器
- 运行容器并连接到刚才新建的网络
mynet:
docker run -it --rm --name busybox1 --network mynet busybox sh

- 打开新的终端,再运行一个容器并加入到
mynet网络:
docker run -it --rm --name busybox2 --network mynet busybox sh

- 再打开一个终端查看容器信息:

- 使用
ping命令来验证两个容器建立了互联关系:


3 配置DNS
Docker利用虚拟文件来挂载容器的 3 个相关配置文件;- 通过
mount命令查看挂载信息:

- 宿主主机
DNS信息发生更新后,所有Docker容器的 DNS 配置通过/etc/resolv.conf文件立刻得到更新; - 配置全部容器
DNS,也可以在/etc/docker/daemon.json文件中增加以下内容来设置:
{
"dns" : [
"123.123.123.123",
"6.6.6.6"
]
}
- 则,每次启动容器
DNS为以上的配置。使得配置生效的命令为:
docker run -it --rm ubuntu:18.04 cat etc/resolv.conf

浙公网安备 33010602011771号