Docker端口映射和容器互联
一、端口映射实现容器访问
1.从外部访问容器应用
在启动容器时如果不指定对应参数,在容器外部是无法通过网络来访问容器内的网络应用和服务的。
-P:随机映射一个49000-49900的端口到内部容器开放的网络端口:
D:\docker_test>docker run -d -P training/webapp python app.py fe09381970267dfecb92079d0da1047386253d6a8e834d3b6232dd0dc3b7a20c D:\docker_test>docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES fe0938197026 training/webapp "python app.py" 16 seconds ago Up 11 seconds 0.0.0.0:49153->5000/tcp tender_tesla
通过docker ps看到本机49153端口映射到容器的5000端口。此刻访问本机的49153端口即可访问容器内web应用提供的界面。
-p:可以指定要映射的端口,并且在一个指定的端口上只能绑定一个容器。
2.映射所有接口地址
D:\docker_test>docker run -d -p 5000:5000 training/webapp python app.py
可以使用多次-p标记可以绑定多个参数
D:\docker_test>docker run -d -p 5000:5000 -p 3000:80 training/webapp python app.py
3.映射到指定地址的指定端口
D:\docker_test>docker run -d -p 127.0.0.1:5000:5000 training/webapp python app.py
4.映射到指定地址的任意端口
D:\docker_test>docker run -d -p 127.0.0.1::5000 training/webapp python app.py
还可以使用upd标记来指定udp端口
D:\docker_test>docker run -d -p 127.0.0.1:5000:5000/udp training/webapp python app.py
5.查看端口映射配置
D:\docker_test>docker port de286751263c 5000/udp -> 127.0.0.1:5000
二、容器互联
使用--link选项可以让容器之间安全的进行交互
1)创建一个新的数据库容器
D:\docker_test>docker run -d --name db training/postgres
2)创建一个web容器,并将它连接到db容器
D:\docker_test>docker run -d -P --name web --link db:db training/webapp python app.py
--links格式:--link name:alias,name是要连接的容器名称,alias是起的别名
Docker通过两种方式为容器公开连接信息:
- 更新环境变量
- 更新/etc/hosts文件