上节咱们学习了容器如何访问外部网络,今天讨论另外一个方向:外部网络如何访问到容器?答案是:端口映射。html
docker 可将容器对外提供服务的端口映射到 host 的某个端口,外网经过该端口访问容器。容器启动时经过-p
参数映射端口:web
root@cuiyongchao:~# docker run -d -p 80 httpd b23b69fe10f6013f1761867be1ba7cc1a4f7b8586c7aa8d0526ba9305cde76f3 root@cuiyongchao:~# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES b23b69fe10f6 httpd "httpd-foreground" 12 seconds ago Up 7 seconds 0.0.0.0:32768->80/tcp upbeat_kalam
容器启动后,可经过 docker ps
或者 docker port
查看到 host 映射的端口。在上面的例子中,httpd 容器的 80 端口被映射到 host 32768 上,这样就能够经过 <host ip>:<32768>
访问容器的 web 服务了。docker
root@cuiyongchao:~# docker port b23b69fe10f6 80/tcp -> 0.0.0.0:32768 root@cuiyongchao:~# curl 10.0.0.20:32768 <html><body><h1>It works!</h1></body></html> root@cuiyongchao:~#
除了映射动态端口,也可在 -p
中指定映射到 host 某个特定端口,例如可将 80 端口映射到 host 的 8080 端口:网络
root@cuiyongchao:~# docker run -d -p 8080:80 httpd 904af8b80ff3f45a79a2b96d25b0a56232e57c7cacab7376972454fa5e094256 root@cuiyongchao:~# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 904af8b80ff3 httpd "httpd-foreground" 6 seconds ago Up 3 seconds 0.0.0.0:8080->80/tcp optimistic_allen root@cuiyongchao:~# curl 10.0.0.20:8080 <html><body><h1>It works!</h1></body></html> root@cuiyongchao:~#
每个映射的端口,host 都会启动一个 docker-proxy
进程来处理访问容器的流量:curl
root@cuiyongchao:~# ps -ef | grep proxy root 105743 87520 0 23:45 ? 00:00:00 /usr/bin/docker-proxy -proto tcp -host-ip 0.0.0.0 -host-port 32768 -container-ip 172.17.0.7 -container-port 80 root 106097 87520 0 23:48 ? 00:00:00 /usr/bin/docker-proxy -proto tcp -host-ip 0.0.0.0 -host-port 8080 -container-ip 172.17.0.8 -container-port 80 root 106301 105610 0 23:50 pts/11 00:00:00 grep --color=auto proxy root@cuiyongchao:~#
以 0.0.0.0:32773->80/tcp 为例分析整个过程:tcp
查看ip方法: root@cuiyongchao:~# docker network inspect bridge 172.17.0.7/16 ps -ef | grep prox
本章小结学习
在这一章咱们首先学习了 Docker 的三种网络:none, host 和 bridge 并讨论了它们的不一样使用场景;而后咱们实践了建立自定义网络;最后详细讨论了如何实现容器与容器之间,容器与外部网络之间的通讯。ui