docker数据持久化
程序员文章站
2022-05-11 22:59:52
...
容器中的数据可以存储在容器层。但是将数据存放在容器层存在以下问题:
数据不是持久化。意思是如果容器删除了,这些数据也就没了
主机上的其它进程不方便访问这些数据
对这些数据的I/O会经过存储驱动,然后到达主机,引入了一层间接层,因此性能会有所下降
Docker 提供了3种持久化数据的方式:
- volumes:存于主机文件系统中的某个区域,由Docker管理(/var/lib/docker/volumes/ on linux)。非Docker进程不应该修改这些数据。卷是Docker中持久化数据的最好方式
- bind mount:存于主机文件系统中的任意位置。非Docker进程可以修改这些数据
- tmpfs mount(Linux中):存于内存中(注意,并不是持久化到磁盘)。在容器的生命周期中,它能被容器用来存放非持久化的状态或敏感信息
volume :用法
场景:
* 多个运行容器间共享数据
* 当Docker主机不确保具有给定的目录或文件时。卷可以将容器运行时与Docker主机的配置解耦合
* 备份、恢复、或将数据从一个Docker主机迁移到另一个Docker主机时
docker run -d -v mysql:/var/lib/mysql --name=mysql1 -e MYSQL_ALLOW_EMPTY_PASSWOED=true -e MYSQL_ROOT_PASSWORD=123456 mysql:5.6
创建:docker volume create
删除某个卷:docker volume rm 卷名
删除所有未使用的卷:docker volume prune
列出所有卷:docker volume ls
查看某个卷的信息:docker volume inspect 卷名
bind mount用法:
大体上来说,只要可能,最好使用volumes
* 主机与容器共享配置文件(Docker默认情况下通过这种方式为容器提供DNS解析,通过将/etc/resolv.conf挂载到容器中)
* 共享源代码或build artifacts(比如将Maven的target/目录挂载到容器中,每次在Docker主机中build
Maven工程时,容器能够访问到那些rebuilt artifacts)
* 当 docker主机中的文件或目录结构和容器需要的一致时