2019年10月

docker数据卷(数据挂载)

1.引言

docker的镜像是由多个只读的文件系统叠加在一起形成的。当我们在我启动一个容器的时候,docker会加载这些只读层并在这些只读层的上面(栈顶)增加一个读写层。这时如果修改正在运行的容器中已有的文件,那么这个文件将会从只读层复制到读写层。该文件的只读版本还在,只是被上面读写层的该文件的副本隐藏。当删除docker,或者重新启动时,之前的更改将会消失。在Docker中,只读层及在顶部的读写层的组合被称为Union File System(联合文件系统)。

为了很好的实现数据保存和数据共享,Docker提出了Volume这个概念,简单的说就是绕过默认的联合文件系统,而以正常的文件或者目录的形式存在于宿主机上。又被称作数据卷。
摘自:https://www.cnblogs.com/lishanlei/p/9503596.html

2.Docker数据管理

docker在容器中管理数据主要有两种方式:

  • 数据卷(Volumes)
  • 挂载主机目录(Bind mounts)

11227136-e5e2fa69a0e8928f.webp

2.1数据卷

数据卷是一个可供一个或多个容器使用的特殊目录,它绕过UFS,可以提供很多有用的特性:

  • 数据卷可以在容器之间共享和重用
  • 对数据卷的修改会立马生效
  • 对数据卷的更新,不会影响镜像
  • 数据卷默认会一直存在,即使容器被删除
    Docker中提供了两种挂载方式,-v和-mount

创建数据卷

docker volume create mydata

查看所有数据卷

docker volume ls

dockerls.png

查看数据卷信息

docker volume inspect mydata

2019-10-16 16-48-19.png

注:Mountpoint为数据在本机存储的位置,如果磁盘存储空间不足可修改此位置

挂载
方式一:

docker run --name xxxx -p 8888:8888 -v /my:/docker -it imagename /bin/bash

--name: 为容器起名字
-p :宿主机端口:docker端口 (端口映射)
-v :宿主机目录:docker目录 (必须为绝对路径)

方式二:
docker run --name xxxx -p 8888:8888 --mount type:volume,source=/src/xxx,target=/xxx /my:/docker -it imagename /bin/bash

type选项,其可以是bind,volume,或 tmpfs。本主题讨论卷,因此类型始终是 volume

注意:使用-v参数时如果本地目录不存在Docker会自动为你创建一个文件夹。使用--mount参数时如果本地目录不存在,Docker会报错。Docker挂载主机目录的默认权限是读写,用户也可以通过增加readonly指定为只读。

  • 如果挂载一个空的数据卷到容器中的一个非空目录中,那么这个目录下的文件会被复制到数据卷中。(我的测试:使用 -v 参数并没有这个效果,需要使--mount参数,如果不符请指正)
  • 如果挂载一个非空的数据卷到容器中的一个目录中,那么容器中的目录中会显示数据卷中的数据。如果原来容器中目录非空,那么这些原始数据会被隐藏掉。

    2.2挂载主机目录

    docker run -it --name c1 -v /宿主机目录:/docker目录 -it imagename /bin/bash
    参考:https://cloud.tencent.com/developer/article/1491692
    https://www.jianshu.com/p/19f12c616d0c

背景介绍
使用elasticsearch时,在集群中进行快照是可能需要使用nfs挂载共享目录,接下来记录下如何使用nfs挂载共享目录。

1.使用root用户进入/etc/exports 文件下配置允许访问的机器的ip以及本机公开的文件目录

/home/xxx/software/es_backup xx.x.x.194(rw)
/home/xxx/software/es_backup xx.x.x.193(rw)

解释:第一个是公开的文件目录,第二个是允许访问机器的ip第三个括号内(rw)是允许读写。

2.启动nfs

service nfs restart

如果不行的话。可以在启动nfs之前,事先启动以下三个命令之一。

service portreserve restart
service rpcbind restart
service portmap restart

解释:以上三个命令启动一个即可,因为linux服务器版本不同,所以不一定哪个起作用。

3.在其他机器挂载此共享目录

mount xxx.xxx.xx.xxx:/home/xx/software/es_backup /home/es/software/test
Unmount /home/es/software/test (取消挂载)

解释:mount 后面跟随的是共享目录主机的ip与文件所在目录,以及你本机的需要放置的目录。

unmount 是你取消挂载这个目录。

4.其他问题

如果nfs出现问题,可能会出现 df ls等等命令无法使用,这样你可以使用

mount |grep nfs 

查看你挂载了的哪些节点,然后将之取消挂载。

最近将博客从wordpress迁移到了typecho记录一下
1.从typecho官网下载给的插件
http://docs.typecho.org/plugins/wordpress-to-typecho
2.根据启用插件按照官网写的步骤进行
中间遇到的问题
1.出现 Database Query Error
解决措施
MySQL5.6的严格模式问题?
然后把严格模式关了,成功转换!
所以解决办法是:
在phpmyadmin/mysql命令行下运行:
代码:

SET GLOBAL sql_mode='';

来源http://forum.typecho.org/viewtopic.php?t=8898