外部服务访问容器
容器中运行应用时,可以通过-P
或 -p
参数来指定端口映射。
当使用 -P
标记时,Docker 会随机映射一个端口到内部容器开放的网络端口。
使用 docker container ls
可以看到,本地主机的 32768 被映射到了容器的 80 端口。此时访问本机的 32768 端口即可访问容器内 NGINX 默认页面。
-p
则可以指定要映射的端口,并且,在一个指定端口上只可以绑定一个容器。支持的格式有 :ip:hostPort:containerPort | ip::containerPort | hostPort:containerPort
映射所有接口地址
使用 hostPort:containerPort
格式本地的 80 端口映射到容器的 80 端口,此时默认会绑定本地所有接口上的所有地址
docker run -d -p 80:80 nginx:alpine
映射到指定地址的指定端口
可以使用 ip:hostPort:containerPort
格式指定映射使用一个特定地址,比如 localhost 地址 127.0.0.1
docker run -d -p 127.0.0.1:80:80 nginx:alpine
映射到指定地址的任意端口
使用 ip::containerPort
绑定 localhost 的任意端口到容器的 80 端口,本地主机会自动分配一个端口。
docker run -d -p 127.0.0.1::80 nginx:alpine
指定协议
docker run -d -p 127.0.0.1:80:80/udp nginx:alpine
查看映射端口配置
使用 docker port
来查看当前映射的端口配置,也可以查看到绑定的地址
-p
标记可以多次使用来绑定多个端口
docker run -d -p 80:80 -p 443:443 nginx:alpine
容器互联
以前使用容器使用--link来使多个容器共享网络,但是现在不建议这么做,可以将容器加入自定义的网络中
docker network create -d bridge my-net
-d
参数指定 Docker 网络类型
运行两个容器并加入自定义网络
docker run -it --rm --name busybox1 --network my-net busybox sh
docker run -it --rm --name busybox2 --network my-net busybox sh
测试网络
/ \# ping busybox1
PING busybox1 (172.19.0.2): 56 data bytes
64 bytes from 172.19.0.2: seq\=0 ttl\=64 time\=0.064 ms
64 bytes from 172.19.0.2: seq\=1 ttl\=64 time\=0.143 ms
配置DNS
配置全部容器的 DNS ,也可以在 /etc/docker/daemon.json
文件中增加以下内容来设置
"dns" : [
"114.114.114.114",
"8.8.8.8"
]
查看容器内DNS
如果用户想要手动指定容器的配置,可以在使用 docker run
命令启动容器时加入如下参数:
-h HOSTNAME
或者 --hostname=HOSTNAME
设定容器的主机名,它会被写到容器内的 /etc/hostname
和 /etc/hosts
。但它在容器外部看不到,既不会在 docker container ls
中显示,也不会在其他的容器的 /etc/hosts
看到。
--dns=IP_ADDRESS
添加 DNS 服务器到容器的 /etc/resolv.conf
中,让容器用这个服务器来解析所有不在 /etc/hosts
中的主机名。
--dns-search=DOMAIN
设定容器的搜索域,当设定搜索域为 .example.com
时,在搜索一个名为 host 的主机时,DNS 不仅搜索 host,还会搜索 host.example.com
。
注意:如果在容器启动时没有指定最后两个参数,Docker 会默认用主机上的 /etc/resolv.conf
来配置容器。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。