docker存储卷
数据卷
-
为什么需要数据卷(存储卷)
卷
设置随机卷
[root@centos7-node1 ~]# docker run --name mybbox5 -it -v /mydata --rm busybox /bin/sh #指定容器卷,容器中不存在则自动创建
/ # cd /mydata/
[root@centH . E 1 6os7-node1 ~]# docker inspect mybbox5 # 另起窗口查看挂载
"Mounts": [
{
"Type": "volume",
"Name": "a39b4a68fc51d83g E c C I | B u900093f35b05b4e29085b2d45d1fa9aD 1 C O 9 k 5 ! R19f6% # u 0 =3f75130dbf1d0c",
"Source": "/data/docker/volut & : U tmes/a39R h Yb4a68fc51d83900093f35b05b4e29085b2d45d1fa9a19f63f75130dbf1d0c/_data",
F B 8 R + & & E 1"DesB C 4 w $tination": "/mydata",
"Driver": "local",
"ModeU ( & r s 1": "",
"RW": true,
"Propagation": ""
}
],
绑定G 4 W } N挂载卷
- 绑定本地W l Z 7指定目录到容器的卷
- 特点:
- 删除容器之后本地目录不会被删除,数据还在
- 可以脱离容器的生命周期而存在
- 若有NFS存储的话,数据也可以脱离本机而存在) Q . U n
- 可以实现容器间数据的共享
[root@centos7-node1 ~]# mkdir /data/volumes/v1 -p
[root@* d a ) 1 Q ) ? wcentos7-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
容l % =器间数据共享的案例
[root@centos7-node1 ~]# docker run --name box6 -it -d -v /! } m Q _ F S # 8data/volumes/v1:/mydata busybox /bin/sh
[root@centos7-node1 ~]# docker run --name box7 -it --rm --volumesy . [ # Y k-from box6 busybox
inspect数据显示
[root@cen 0 a K 9 f Ptos7-node1 v1T . j n R z _ N )]# dr F 1 # F & - 9ockeZ i c B 7 ) Q _ ~r inspect box7 #查看容器,找出对应字段
[root@centos7-node1 v1]# docker inspect -f {{.Mounts}} box6 #.MountsR / f ! ] 0 x !是顶级字段
[root@centos7-node1 v1]# docA 0 6 i -ker inspect -f {{.NetworkSettings.Networks.bridge}} box7 #多级字段之间用.连接
实战
-
容器化部署wordpress
- p # } i ] ? h php+http
- nginx 配置文件本地存储
- mysql
- 网页数据和mysql数据存储到本地
- mysql需要在启动时传入
-e MYSQL_ROOTPASSW( 1 ~ :ORD=hello
- 思路
- 这三个应用的容器在同一网络层
- 配置文件和数据文件需要和本地使用绑定卷存储
[root@centos7-node1 ~]# mkdir /data/volumes/mysql
[root@centos7-, M = |node1 ~]# docker pull mysql:5.5
[root@centos7-node1 ~]# docker run --name db -d -v /data/volumes/mysql:/var/lib/mysql -e MYSQL_ROOT_$ + cPASSWORD=qwer1234 mysql:5.5
[root@centos7-node1 ~]# dockeq B zr 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 'wpss2020U t ^ ^ , o 9 e'b S & { =;
[root@centos7-node1 ~]# docker pull php:5.6-fpm
[root@centos7-node1 ~]# docker pull nginx:1.18-alpine
[root@centos7-node1 ~]#mkdir /data/volu# X c 7 4 g i vmes/nginx_conf -p #nginx配置文件目录
[root@cA @ $ x x Pentos7-node1 ~]# cat /da2 f ,ta/volumeP ; T 7 s 6 D Us/n: 8 t p B O F v Hginx_conf/nginx_php.conf #定义好Ngg f !inx-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/ ! V 3 V N L * @share/nginx/html;( # 3 x + ~ U #
}
location ~ .php$ {
fastcgi_pass p{ m t Php:9000;
fastcgi_index iN + T 7 % n F -ndexr E :.php;
fastcgi_param SCRIPTK R T Y U_FILENAME /www/wordpress/$fastcgi_sc& L T L c n `ript_nu D uame;
include fastcgi_params;
}
}
[root@centos7-node1 ~]# docker run --name php-fpm -d -v /data/volumes/web:/www php:5.6-fpm #启动php
[root@ceJ y pntos7-node1 ~]# docker run --name nginx_php -d -p 80:80 -v /data/volumes/nginx_conf:/etc/nginx/conf.d -5 Z g D H Q-volumes-f- / X / e Mrom php-fpm --li& & E c G b y Jnk php-fpm:php( H } ] 3 - } nginx:1.18-alpine #启动n/ J o n Iginx
[root@centos7-node1 ~]# cd /data/volumes/web && wget https://woo L B J Krdpress.org/latest.zip
root@cX $ @ 4 E I 8 . wentos7-node1 web]# unzip wordpt b & p s $ress-5.4.1.ziY * R ^p
[root@centos7-node1 ~]# d7 6 v bocker exec nginx_php nginx -s reload
发表评论