docker数据持久化

容器中的数据可以存储在容器层。但是将数据存放在容器层存在以下问题:

数据不是持久化。意思是如果容器删除了,这些数据也就没了
主机上的其它进程不方便访问这些数据
对这些数据的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主机中的文件或目录结构和容器需要的一致时
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值