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文件
原文地址:https://www.cnblogs.com/shier-dong/p/15490208.html