在Docker中,为了方便查看容器内产生的数据或者将多个容器中的数据实现共享,就涉及到容器的数据管理操做。
管理Docker容器中数据只要有两种方式:数据卷(Data Volumes)和数据卷容器(Data Volumes Containers) nginx
数据卷是一个供容器使用的特殊目录,位于容器中,可将宿主机的目录挂载到数据卷上,对数据卷的修改操做马上可见,而且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。web
在docker run命令中使用-v选项能够在容器内建立数据卷。屡次使用-v选项能够建立多个数据卷。使用--name选项能够给容器建立一个有好的自定义名称。docker
例子:centos
docker pull centos #下载镜像
#宿主机目录/var/www 挂载容器中的/data1
docker run -v /var/www:/data1 --name web1 -it centos /bin/bash
[root@63031797b41f /]# cd /data1/
[root@63031797b41f data1]# touch test
[root@63031797b41f data1]# exit
#返回宿主机进行查看
[root@localhost ~]# ls /var/www/bash
若是须要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器就是一个普通的容器,专门提供数据卷给其余容器挂载使用。
使用方法:首先,须要建立一个容器作为数据卷容器。以后在其余容器建立时用 --volumes-from 挂载数据卷容器中的数据使用。网络
例子:ide
docker run --name web200 -v /data1 -v /data2 -it centos /bin/bash #建立2个数据卷/data1,/data2, 数据卷容器web200
exit
#新容器db1挂载到数据卷容器web200
docker run -it --volumes-from web200 --name db1 centos /bin/bash
mkdir /data1/test2 #在容器db1里面创建目录test2
exit
docker start web200 #启动数据卷容器
docker exec -it web200 /bin/bash #进入数据卷容器
[root@065387b882cb /]# ls /data1/ #在数据卷容器web200能够看到新容器db1新建目录
test2测试
Docker提供端口映射机制来将容器内的服务提供给外部网络访问,实质上就是将宿主机的端口映射到容器中,使得外部网络访问宿主机的端口即可以访问容器内的服务。3d
例子:blog
docker pull nginx #下载镜像
docker run -d -P nginx #运行镜像 -P(大写)随机映射端口
网页验证:
或者:
docker run -d -p 81:80 nginx #指定映射端口81
docker ps -a
网页验证:
docker run -P --name web1 -itd nginx /bin/bash #建立并运行容器取名web1,端口号自动映射
docker run -P --name web2 --link web1:web1 -itd nginx /bin/bash #建立并运行容器取名web2,连接到web1和其通讯
进web2 容器 ping 源容器
docker exec -it 9ee4fdb533ac /bin/bash
ping web1
若是出现下面问题:
能够这样解决:
apt-get update
apt install iputils-ping
再尝试ping web1: