一、docker数据管理
在容器中管理数据主要有两种方式:数据卷(Volumes)、挂载主机目录(Bind mounts)
1.1、数据卷
数据卷是一个可供一个或多个容器使用的特殊目录,它绕过UFS,
提供很多有用的特性:
1、数据卷可以在容器之间共享和重用
2、对数据卷的修改会立马生效
3、对数据卷的更新,不会影响镜像
4、数据卷默认会一直存在,即使容器被删除
注意:数据卷的使用,类似于Linux下对目录或文件进行mount,镜像中的被指定为挂载点的目录中的文件会隐藏掉,能显示看的是挂载的数据卷。
docker的两种挂载方式:
-v、-mount;推荐用-mount
1.1.1、创建一个数据卷
docker volume create [name]
1.1.2、查看所有的数据卷
docker volume ls
1.1.3、查看指定数据卷的信息
docker volume inspect my-volume
1.1.4、启动一个挂载数据卷的容器
在用docker run命令的时候,使用 --mount标记来将数据卷挂载到容器里。
在一次docker run中可以挂载多个数据卷。
1.1.5、(例子)创建一个名为session-web的容器
加载一个数据卷到容器的/webapp目录。
docker run --name session-web -d -p 8888: 8080 \
#-v my-volume: /wepapp \
--mount source=my-volume,target=/ webapp \
session-web: latest
1.1.6、删除数据卷
docker volume rm my-volume
数据卷是被设计用来持久化数据的,它的生命周期独立于容器,docker不会在容器被删除后自动删除数据卷,并且也不存在垃圾回收这样的机制:来处理没有任何容器引用的数据卷。
如果需要在删除容器的同时移除数据卷。可以在删除容器的时候使用docker rm -v来删除数据卷。
无主的数据卷可能会占据很多空间,要清理可以使用如下命令
docker volume prune
1.1.7、指定挂载一个本地主机的目录到容器中
使用--mount标记可以指定挂载一个本地主机的目录到容器中去
docker run --name session-web -d -p 8888: 8080 \
#-v my-volume: /wepapp \
--mount type=bind,source=/src/webapp,target=/opt/webapp
session-web: latest
上面的命令加载主机的/src/webapp目录到容器的/opt/ webapp目录。这个功能在进行测试的时
候十分方便,比如用户可以放置一些程序到本地目录中,来查看容器是否正常工作。
本地目录的路径必须是绝对路径
以前------使用-v参数时,如果本地目录不存在,docker会自动创建一个文件夹
现在------使用–mount参数时,如果本地目录不存在,docker会报错
docker挂载主机目录的默认权限是读写,用户也可以通过增加readonly指定为只读。
1.1.8、从主机挂载单个文件到容器中
使用–mount标记也可以从主机挂载单个文件到容器中
docker run --rm-it \
#-v $HOME/bash_history: /root/.bash_history \
--mount type=bind.source=$HOME/bash_history,target=/root/.bash_ history \
ubuntu: 17.10\
bash
这样就可以记录在容器输入过的命令了