docker存储卷
数据卷
- 为什么需要数据卷(存储卷)
- docker镜像由多个
只读层
叠加而成,启动容器时,docker会加载只读镜像层,并在镜像层添加一个读写层
- 如果运行中的容器修改了现有的一个已经存在的文件,那么该文件将会从读写层下面的只读层复制到读写层,该文件的只读版本仍然存在,只是已经被读写层中该文件的副本所隐藏,这就是
COW(写时复制)
机制
- docker镜像由多个
- 关闭并重启容器,其数据不受影响,但是删除容器,则其更改将会全部丢失
- 存在的问题:
- 存储与联合文件系统中,不易于宿主机访问
- 容器键数据共享不便
- 删除容器其数据会丢失
卷
-
什么是卷
- 卷是容器上的一个或者多个
目录
,此类目录可以绕过联合文件系统,与宿主机上的某个目录可以绑定(关联)
- 卷是容器上的一个或者多个
设置随机卷
[root@centos7-node1 ~]# docker run --name mybbox5 -it -v /mydata --rm busybox /bin/sh #指定容器卷,容器中不存在则自动创建
/ # cd /mydata/
[root@centos7-node1 ~]# docker inspect mybbox5 # 另起窗口查看挂载
"Mounts": [
{
"Type": "volume",
"Name": "a39b4a68fc51d83900093f35b05b4e29085b2d45d1fa9a19f63f75130dbf1d0c",
"Source": "/data/docker/volumes/a39b4a68fc51d83900093f35b05b4e29085b2d45d1fa9a19f63f75130dbf1d0c/_data",
"Destination": "/mydata",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
}
],
image.png
绑定挂载卷
-
绑定本地指定目录到容器的卷
-
特点:
- 删除容器之后本地目录不会被删除,数据还在 - 可以脱离容器的生命周期而存在 - 若有NFS存储的话,数据也可以脱离本机而存在 - 可以实现容器间数据的共享
[root@centos7-node1 ~]# mkdir /data/volumes/v1 -p
[root@centos7-node1 v1]# echo "hello" > /data/volumes/v1/my.txt
[root@centos7-node1 ~]# docker run --name mybox -it -v /data/volumes/v1:/mydata busybox /bin/sh
[root@centos7-node1 ~]# docker rm mybox
mybox
[root@centos7-node1 ~]# ls /data/volumes/v1/
my.txt
容器间数据共享的案例
[root@centos7-node1 ~]# docker run --name box6 -it -d -v /data/volumes/v1:/mydata busybox /bin/sh
[root@centos7-node1 ~]# docker run --name box7 -it --rm --volumes-from box6 busybox
inspect数据显示
[root@centos7-node1 v1]# docker inspect box7 #查看容器,找出对应字段
[root@centos7-node1 v1]# docker inspect -f {{.Mounts}} box6 #.Mounts是顶级字段
[root@centos7-node1 v1]# docker inspect -f {{.NetworkSettings.Networks.bridge}} box7 #多级字段之间用.连接
实战
-
容器化部署wordpress
-
php+http
-
nginx 配置文件本地存储
-
mysql
-
网页数据和mysql数据存储到本地
-
mysql需要在启动时传入
-e MYSQL_ROOTPASSWORD=hello
-
-
思路
-
这三个应用的容器在同一网络层
-
配置文件和数据文件需要和本地使用绑定卷存储
-
[root@centos7-node1 ~]# mkdir /data/volumes/mysql
[root@centos7-node1 ~]# docker pull mysql:5.5
[root@centos7-node1 ~]# docker run --name db -d -v /data/volumes/mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=qwer1234 mysql:5.5
[root@centos7-node1 ~]# docker exec -it db /bin/bash #进入数据库,创建用户以及数据库
root@38b54e3d76cf:/# mysql -uroot -p
mysql> create database wordpress charset utf8;
mysql> grant all on wordpress.* to 'wordpress'@'127.0.0.1' identified by 'wpss2020';
[root@centos7-node1 ~]# docker pull php:5.6-fpm
[root@centos7-node1 ~]# docker pull nginx:1.18-alpine
[root@centos7-node1 ~]#mkdir/data/volumes/nginx_conf -p #nginx配置文件目录
[root@centos7-node1 ~]# cat /data/volumes/nginx_conf/nginx_php.conf #定义好Nginx-php配置文件
server {
listen 80;
server_name localhost;
location / {
root /www/wordpress;
index index.php;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
location ~ \.php$ {
fastcgi_pass php:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /www/wordpress/$fastcgi_script_name;
include fastcgi_params;
}
}
[root@centos7-node1 ~]# docker run --name php-fpm -d -v /data/volumes/web:/www php:5.6-fpm #启动php
[root@centos7-node1 ~]# docker run --name nginx_php -d -p 80:80 -v /data/volumes/nginx_conf:/etc/nginx/conf.d --volumes-from php-fpm --link php-fpm:php nginx:1.18-alpine #启动nginx
[root@centos7-node1 ~]# cd /data/volumes/web && wget https://wordpress.org/latest.zip
root@centos7-node1 web]# unzip wordpress-5.4.1.zip
[root@centos7-node1 ~]# docker exec nginx_php nginx -s reload
网友评论