共计 3773 个字符,预计需要花费 10 分钟才能阅读完成。
Docker 容器连贯
后面咱们实现了通过网络端口来拜访运行在 docker 容器内的服务。
容器中能够运行一些网络应用,要让内部也能够拜访这些利用,能够通过 -P 或 -p 参数来指定端口映射。
上面咱们来实现通过端口连贯到一个 docker 容器。
网络端口映射
咱们创立了一个 python 利用的容器。
xxx@xxx:~$ docker run -d -P training/webapp python app.py
fce072cc88cee71b1cdceb57c2821d054a4a59f67da6b416fceb5593f059fc6d
另外,咱们能够指定容器绑定的网络地址,比方绑定 127.0.0.1。
咱们应用 -P 绑定端口号,应用 docker ps 能够看到容器端口 5000 绑定主机端口 32768。
xxx@xxx:~$ docker ps
CONTAINER ID IMAGE COMMAND ... PORTS NAMES
fce072cc88ce training/webapp "python app.py" ... 0.0.0.0:32768->5000/tcp grave_hopper
咱们也能够应用 -p 标识来指定容器端口绑定到主机端口。
两种形式的区别是:
-P : 是容器外部端口 随机映射到主机的高端口。
-p : 是容器外部端口绑定到 指定的主机端口。
xxx@xxx:~$ docker run -d -p 5000:5000 training/webapp python app.py33e4523d30aaf0258915c368e66e03b49535de0ef20317d3f639d40222ba6bc0
xxx@xxx:~$ docker ps
CONTAINER ID IMAGE COMMAND ... PORTS NAMES33e4523d30aa training/webapp "python app.py" ... 0.0.0.0:5000->5000/tcp berserk_bartik
fce072cc88ce training/webapp "python app.py" ... 0.0.0.0:32768->5000/tcp grave_hopper
另外,咱们能够指定容器绑定的网络地址,比方绑定 127.0.0.1。
xxx@xxx:~$ docker run -d -p 127.0.0.1:5001:5000 training/webapp python app.py95c6ceef88ca3e71eaf303c2833fd6701d8d1b2572b5613b5a932dfdfe8a857cxxx@xxx:~$ docker ps
CONTAINER ID IMAGE COMMAND ... PORTS NAMES95c6ceef88ca training/webapp "python app.py" ... 5000/tcp, 127.0.0.1:5001->5000/tcp adoring_stonebraker33e4523d30aa training/webapp "python app.py" ... 0.0.0.0:5000->5000/tcp berserk_bartik
fce072cc88ce training/webapp "python app.py" ... 0.0.0.0:32768->5000/tcp grave_hopper
这样咱们就能够通过拜访 127.0.0.1:5001 来拜访容器的 5000 端口。
下面的例子中,默认都是绑定 tcp 端口,如果要绑定 UDP 端口,能够在端口前面加上 /udp。
x
xx@xxx:~$ docker run -d -p 127.0.0.1:5000:5000/udp training/webapp python app.py6779686f06f6204579c1d655dd8b2b31e8e809b245a97b2d3a8e35abe9dcd22axxx@xxx:~$ docker ps
CONTAINER ID IMAGE COMMAND ... PORTS NAMES6779686f06f6 training/webapp "python app.py" ... 5000/tcp, 127.0.0.1:5000->5000/udp drunk_visvesvaraya95c6ceef88ca training/webapp "python app.py" ... 5000/tcp, 127.0.0.1:5001->5000/tcp adoring_stonebraker33e4523d30aa training/webapp "python app.py" ... 0.0.0.0:5000->5000/tcp berserk_bartik
fce072cc88ce training/webapp "python app.py" ... 0.0.0.0:32768->5000/tcp grave_hopper
docker port 命令能够让咱们快捷地查看端口的绑定状况。
xxx@xxx:~$ docker port adoring_stonebraker 5000127.0.0.1:5001
Docker 容器互联
端口映射并不是惟一把 docker 连贯到另一个容器的办法。
docker 有一个连贯零碎容许将多个容器连贯在一起,共享连贯信息。
docker 连贯会创立一个父子关系,其中父容器能够看到子容器的信息。
容器命名
当咱们创立一个容器的时候,docker 会主动对它进行命名。另外,咱们也能够应用 –name 标识来命名容器,例如:
xxx@xxx:~$ docker run -d -P --name xxx training/webapp python app.py43780a6eabaaf14e590b6e849235c75f3012995403f97749775e38436db9a441
咱们能够应用 docker ps 命令来查看容器名称。
xxx@xxx:~$ docker ps -l
CONTAINER ID IMAGE COMMAND ... PORTS NAMES43780a6eabaa training/webapp "python app.py" ... 0.0.0.0:32769->5000/tcp xxx
新建网络
上面先创立一个新的 Docker 网络。
$ docker network create -d bridge test-net
参数阐明:
-d:参数指定 Docker 网络类型,有 bridge、overlay。
其中 overlay 网络类型用于 Swarm mode,在本大节中你能够疏忽它。
连贯容器
运行一个容器并连贯到新建的 test-net 网络:
$ docker run -itd --name test1 --network test-net ubuntu /bin/bash
关上新的终端,再运行一个容器并退出到 test-net 网络:
$ docker run -itd --name test2 --network test-net ubuntu /bin/bash
点击图片查看大图:
上面通过 ping 来证实 test1 容器和 test2 容器建设了互联关系。
如果 test1、test2 容器内中无 ping 命令,则在容器内执行以下命令装置 ping(即学即用:能够在一个容器里装置好,提交容器到镜像,在以新的镜像从新运行以上俩个容器)。
apt-get update
apt install iputils-ping
同理在 test2 容器也会胜利连贯到:
点击图片查看大图:
这样,test1 容器和 test2 容器建设了互联关系。
如果你有多个容器之间须要相互连贯,举荐应用 Docker Compose,前面会介绍。
配置 DNS
咱们能够在宿主机的 /etc/docker/daemon.json 文件中减少以下内容来设置全副容器的 DNS:
{
"dns" : [
"114.114.114.114",
"8.8.8.8"
]}
设置后,启动容器的 DNS 会主动配置为 114.114.114.114 和 8.8.8.8。
配置完,须要重启 docker 能力失效。
查看容器的 DNS 是否失效能够应用以下命令,它会输入容器的 DNS 信息:
$ docker run -it --rm ubuntu cat etc/resolv.conf
手动指定容器的配置
如果只想在指定的容器设置 DNS,则能够应用以下命令:
$ docker run -it --rm -h host_ubuntu --dns=114.114.114.114 --dns-search=test.com ubuntu
参数阐明:
–rm:容器退出时主动清理容器外部的文件系统。
-h HOSTNAME 或者 –hostname=HOSTNAME:设定容器的主机名,它会被写到容器内的 /etc/hostname 和 /etc/hosts。
–dns=IP_ADDRESS:增加 DNS 服务器到容器的 /etc/resolv.conf 中,让容器用这个服务器来解析所有不在 /etc/hosts 中的主机名。
–dns-search=DOMAIN:设定容器的搜寻域,当设定搜寻域为 .example.com 时,在搜寻一个名为 host 的主机时,DNS 不仅搜寻 host,还会搜寻 host.example.com。
点击图片查看大图:
如果在容器启动时没有指定 –dns 和 –dns-search,Docker 会默认用宿主主机上的 /etc/resolv.conf 来配置容器的 DNS。