跟我一块儿学docker(七)--网络

1.容器对外服务mysql


当容器内运行一些网络应用,要让外部访问这些应用时,能够经过 -P 或 -p 参数来指定端口映射。web

使用 -P 映射时,Docker会随机映射一个49000 ~49900 的端口至容器内部开放的端口:sql

docker run -d -P --namemysql mysql:5.6docker

经过docker ps能够看到端口映射关系。能够经过映射在宿主机的端口来访问对应容器内的服务。数据库

进入docker的官网下载mysql镜像ubuntu




tag是mysql的版本号,这里我们选择mysql5.6tomcat



映射到指定宿主机的端口:安全

docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag网络

-e 是环境变量的意思 运行容器内的环境变量设置mysql的密码app


容器里面的mysql已经启动了如今我们为了映射端口的话删除这个mysql容器


映射到指定地址的指定端口,为例:

docker run -d -p 3306:3306 --name mysql mysql:5.6

外部访问虚拟机的3306直接映射到容器的3306链接到数据库



映射到指定地址的指定端口,以127.0.0.1为例:

docker run -d -p127.0.0.1:3306:3306 --name mysql mysql:5.6




映射到指定地址的任意端口,以127.0.0.1为例:

docker run -d -p 127.0.0.1::3306 --name mysqlmysql:5.6

查看映射端口配置:

docker port mysql 3306


2.容器间相互通讯

经过映射宿主机的端口实现容器的互联。


容器的链接(link)除了端口映射外的另外一种能够与容器中应用进行交互的方式。


使用 --link 参数能够让容器之间安全的进行交互。

建立一个数据库容器:

docker run -d --namemysqldb mysql:5.6

建立一个web容器并和数据库容器创建链接:

docker run -d --name Webapp–p 8000:8080 --link mysqldb:MySQL tomcat

上边的MySQL别名就相似dns解析的方式,我给这个容器起了个别名叫MySQL,我就经过这个别名就能够找到对应的这个mysqldb容器

mysqldb容器和web容器创建互联关系。

--link参数的格式为--link name:alias,其中name是要链接的容器名称,alias是这个链接的别名。

能够使用docker ps(PORT字段)来查看容器的链接。

Docker在两个容器之间建立了安全隧道,并且不用映射它们的端口到宿主机上。在启动mysqldb的时候并无使用-p和-P标记,从而避免的了暴露数据库的端口到外部的网络上。

link就是容器直接互相通讯的






Docker经过两种方式为容器公开链接信息:

1 环境变量:

使用env命令来查看。

EX:

docker run --rm --name test--link dblink:dblink ubuntu env

2 更新/etc/hosts文件

查看/etc/hosts文件。

往期docker学习:

认识docker

核心概念和安装

镜像的经常使用操做

容器的基本操做

仓库

数据管理

相关文章
相关标签/搜索