欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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主机中的文件或目录结构和容器需要的一致时
相关标签: docker