前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >kubernetes(四)之Docker存储卷

kubernetes(四)之Docker存储卷

作者头像
alexhuiwang
发布2020-09-23 11:36:56
5920
发布2020-09-23 11:36:56
举报
文章被收录于专栏:运维博客

docker存储卷

数据卷

  • 为什么需要数据卷(存储卷)
    • docker镜像由多个只读层叠加而成,启动容器时,docker会加载只读镜像层,并在镜像层添加一个读写层
    • 如果运行中的容器修改了现有的一个已经存在的文件,那么该文件将会从读写层下面的只读层复制到读写层,该文件的只读版本仍然存在,只是已经被读写层中该文件的副本所隐藏,这就是COW(写时复制)机制
    • 关闭并重启容器,其数据不受影响,但是删除容器,则其更改将会全部丢失
    • 存在的问题:
      • 存储与联合文件系统中,不易于宿主机访问
      • 容器键数据共享不便
      • 删除容器其数据会丢失

  • 什么是卷
    • 卷是容器上的一个或者多个目录,此类目录可以绕过联合文件系统,与宿主机上的某个目录可以绑定(关联)

设置随机卷

代码语言:javascript
复制
[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": ""
            }
        ],
绑定挂载卷
  • 绑定本地指定目录到容器的卷
  • 特点:
    • 删除容器之后本地目录不会被删除,数据还在
    • 可以脱离容器的生命周期而存在
    • 若有NFS存储的话,数据也可以脱离本机而存在
    • 可以实现容器间数据的共享
代码语言:javascript
复制
[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

容器间数据共享的案例

代码语言:javascript
复制
[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数据显示

代码语言:javascript
复制
[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
  • 思路
    • 这三个应用的容器在同一网络层
    • 配置文件和数据文件需要和本地使用绑定卷存储
代码语言:javascript
复制
[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
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/06/04 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • docker存储卷
    • 数据卷
      • 设置随机卷
    • 实战
    相关产品与服务
    容器服务
    腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档