6. docker 的数据卷

最后更新于:2022-04-02 01:41:00

# 6. docker 的数据卷 #### 1. 介绍 上一篇:[使用Dockerfile文件(五)](https://www.rails365.net/articles/shi-yong-dockerfile-wen-jian-wu) 之前有说过,在docker容器上进行的更改并不会主动被保存下来,除非你commit了,不然你重新运行这个镜像,生成新的容器,之前容器的内容就会没有了,因为容器只是一个进程而已。 所以说,容器运行时应该尽量保持容器存储层不发生写操作。 但是,有时候我们需要存储持久化的数据,比如数据库,你的数据都在容器中,肯定是不行的,因为一退出就没有了。 这个时候需要用到`数据卷`。 `数据卷`就是可以让你把主机上的数据以挂载的方式链接到容器中,这样不同的容器也能共享,而且数据也不会因为容器的退出而丢失。 这个`数据卷`会被经常使用。 #### 2. 使用 下面我们来体会一下`数据卷`的功能。 ``` $ docker run -d -v ~/mynginx:/a -p 80:80 --name webserver nginx ``` 这里命令会挂载主机的目录`~/mynginx`到容器中的目录`/a`。 你可以试验一下,分别在两端更改内容,比如新建一个文件,看是不是都变化了。 我们也可以创建数据卷容器,数据卷容器也是一个正常的容器,这种容器可以为其他容器提供和共享数据。 比如,下面创建了一个数据卷容器: ``` $ sudo docker run -d -v /dbdata --name dbdata training/postgres echo Data-only container for postgres ``` 然后其他容器要使用这个数据卷容器的话,只要使用`--volumes-from`参数即可。 ``` $ sudo docker run -d --volumes-from dbdata --name db1 training/postgres $ sudo docker run -d --volumes-from dbdata --name db2 training/postgres ``` 完结。 下一篇:[Docker Compose 的介绍与安装 (七)](https://www.rails365.net/articles/docker-compose-de-jie-shao-yu-an-zhuang-qi)
';