Docker学习之网络篇

Docker 中的网络功能介绍nginx

Docker 容许经过外部访问容器或容器互联的方式来提供网络服务。git


外部访问容器docker

容器中运行的网络应用,外部要访问这些应用。能够经过-P 或 -p 参数指定端口映射。json

-P 参数,会随机映射一个端口到内部容器开放的网络端口。ubuntu

# docker run -d -P nginxcentos

# docker container ls浏览器

CONTAINER ID        IMAGE               COMMAND                  CREATED            STATUS              PORTSbash

44769d42111f        nginx               "nginx -g 'daemon of…"   8 seconds ago       Up 7 seconds       0.0.0.0:32768->80/tcp服务器

QQ截图20180516155802.jpg


能够经过docker logs 查看容器应用的信息网络

# docker logs agitated_visvesvaraya

172.17.0.1 - - [16/May/2018:07:57:27 +0000] "HEAD / HTTP/1.1" 200 0 "-" "curl/7.29.0" "-"

-p 能够指定要映射的端口,而且在一个指定端口上只能够绑定一个容器。


映射全部接口地址

使用 hostPort:containerPort 格式本地的 5000 端口映射到容器的 5000 端口,能够执行

# docker run -d -p 8080:80 nginx

此时默认会绑定本地全部接口上的全部地址。


映射到指定地址的指定端口

可使用 ip:hostPort:containerPort 格式指定映射使用一个特定地址,好比 localhost 地址 127.0.0.1

# docker run -d -p 127.0.0.1:8080:80 nginx

QQ截图20180516160929.jpg

只能本地访问,浏览器访问192.168.20.11:8080 没法访问;



映射到指定地址的任意端口

# docker run -d -p 127.0.0.1::80 nginx

绑定localhost的任意端口到容器80端口,本地会随机分配端口

QQ截图20180516161313.jpg


绑定本地ip地址,浏览器能够访问,localhost不能访问。

# docker run -d -p 192.168.20.11::80 nginx

# curl http://localhost:32768 -I

curl: (7) Failed connect to localhost:32768; Connection refused

# curl http://192.168.20.11:32768 -I

HTTP/1.1 200 OK

QQ截图20180516161932.jpg


还能够指定udp端口

# docker run -d -p 127.0.0.1:8080:80/udp nginx

经过nc命令监测udp端口状态

# nc -vuz 127.0.0.1 8080


查看映射端口配置

查看当前映射的端口配置,也能够看到绑定的地址

# docker port pedantic_wozniak 80

QQ截图20180516164538.jpg

# docker port  <容器NAME> 80

0.0.0.0:32768


-p 能够屡次使用来绑定多个端口

# docker run -d -p 8080:80 -p 8888:80 nginx


本地8080、8888都映射到容器的80端口

# curl http://localhost:8080 -I

HTTP/1.1 200 OK

# curl http://localhost:8888 -I

HTTP/1.1 200 OK




容器互联

建议将容器加入自定义的Dokcer网络来链接多个容器,少使用--link参数。


新建docker网络

# docker network create -d bridge my-net

-d 参数指定docker网络类型,有bridge、 overlay(用于swarm mode)


链接容器

运行一个容器并链接到新建的my-net网络

# dockerun -it --rm --name box1 --network my-net centos sh

打开新的终端,再运行一个容器并加入到 my-net网络

# docker run -it --rm --name box2 --network my-net centos sh

再打开一个新终端,查看容器

经过ping 证实box1 和box2 容器创建互联关系

在box1执行ping box2 ,解析为172.18.0.3

sh-4.2# ping box2 -c 3

PING box2 (172.18.0.3) 56(84) bytes of data.

64 bytes from box2.my-net (172.18.0.3): icmp_seq=1 ttl=64 time=0.048 ms

64 bytes from box2.my-net (172.18.0.3): icmp_seq=2 ttl=64 time=0.135 ms

64 bytes from box2.my-net (172.18.0.3): icmp_seq=3 ttl=64 time=0.123 ms


在box2执行ping box1,成功链接。

sh-4.2# ping box1

PING box1 (172.18.0.2) 56(84) bytes of data.

64 bytes from box1.my-net (172.18.0.2): icmp_seq=1 ttl=64 time=0.448 ms

64 bytes from box1.my-net (172.18.0.2): icmp_seq=2 ttl=64 time=0.134 ms

64 bytes from box1.my-net (172.18.0.2): icmp_seq=3 ttl=64 time=0.130 ms


box1和box2 在同一个局域网内。


Docker Compose

若是你有多个容器之间须要互相链接,推荐使用 Docker Compose




配置DNS


配置所有容器的 DNS ,也能够在 /etc/docker/daemon.json 文件中增长如下内容来设置。

# cat /etc/docker/daemon.json
{
"dns" : [
"114.114.114.114",
"8.8.8.8"
]
}

这样每次启动的容器DNS自动配置为114.114.114.114和 8.8.8.8


验证DNS是否生效

# docker run -it --rm ubuntu cat /etc/resolv.conf

nameserver 114.114.114.114

nameserver 8.8.8.8


若是用户想要手动指定容器的配置,能够在使用 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 来配置容器。


举例说明,没有指定参数,使用本机的DNS地址

[root@ip-172-31-10-118 ~]# cat /etc/resolv.conf

nameserver 172.31.0.2

[root@ip-172-31-10-118 ~]# docker run -it centos

[root@814a44d43938 /]# cat /etc/resolv.conf

nameserver 172.31.0.2

[root@814a44d43938 /]# exit

exit


举例说明,指定-h 主机名 --dns dns地址

[root@localhost docker]# docker run -it -h centos77 --dns=4.4.4.4 centos

[root@centos77 /]# cat /etc/resolv.conf

nameserver 4.4.4.4

[root@centos77 /]# cat /etc/hostname

centos77

相关文章
相关标签/搜索