• docker资料卷——mysql


    简介

    docker是运行在虚拟环境中的,这样会有一个问题,那就是储存在docker内的数据会随着docker的重启、宕机而丢失,从而造成不可估量的损失。

    所以docker提供了-v指令,可以将容器内的目录以及文件映射到外部文件系统,容器启动时会读取外部文件系统,从而保证数据的完整性。

    mysql作为最流行的数据库之一,使用范围十分广泛,如果部署在docker却无法持久化怎么办呢?今天就来说一下mysql资料卷。

    MySql资料卷

    mysql需要保存的只有两种文件:数据和配置文件。mysql的默认配置文件是 /etc/mysql/my.cnf (winDocker下是 /etc/my.cnf),如果是docker下的mysql,建议在 /etc/mysql/conf.d 目录中创建 .cnf 文件。新建的文件只要保证后缀名是 cnf 即可覆盖配置项。至于mysql数据存放的目录,可以在mysql配置文件中找到:


    文件写的很清楚,数据保存在 /var/lib/mysql 路径。接下来需要创建存放资料卷的路径,我创建的目录是 /docker/mysql/data 和 /docker/mysql/conf.d,前者是数据目录,后者是配置目录。接下来需要在本机指定位置新建目录(我已经创建好了):


    现在编写命令:

    docker run -itd -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /docker/mysql/data/:/var/lib/mysql/ -v /docker/mysql/conf.d:/etc/mysql/conf.d --name mysql01 mysql

    这命令有些长,解释一下:

    -itd:开启交互模式,模拟终端,后台运行

    -p 3306:3306:对应端口映射到宿主机

    -e MYSQL_ROOT_PASSWORD=123456:设置root账户密码为123456

    -v /docker/mysql/data/:/var/lib/mysql/:将宿主机的 /docker/mysql/data/ 目录与mysql的 /var/lib/mysql/ 同步

    -v /docker/mysql/conf.d:/etc/mysql/conf.d:将宿主机的 /docker/mysql/conf.d 目录与mysql的 /etc/mysql/conf.d 同步

    --name mysql01:自定义容器名称

    mysql:运行的镜像名称

    这一命令执行过后,你会看到新容器mysql01已经正常启动了:


    正常情况下,你设置的目录下会多出一些文件:

    接下来测试一下。通过客户端连接到docker下的mysql(如果不知道如何使用客户端连接docker下的mysql,请翻我之前的博文),新建数据库:


    然后重启docker:

     

    重启成功以后,进入容器查看数据库:


    数据库并没有因为docker重启而被初始化,证明资料卷已经生效。以后再也不怕Docker宕机而数据丢失了。

    后言

    我分别在winDocker和linuxDocker下设置了mysql资料卷,但只有linux可以跑得起来。winDocker的资料卷可以设置成功,但是重启docker后会出现无法启动mysql容器的错误。根据mysql官方声明得知,docker内的mysql官方镜像是oracle公司专门为linux平台构建的,推测winDocker无法正确挂载资料卷应该和官方支持有点原因,建议同学们直接上手linux。

  • 相关阅读:
    读取.properties配置文件并保存到另一个.properties文件内
    kafka启动报错:另一个程序正在使用此文件,进程无法访问。
    使用Spring boot 嵌入的tomcat不能启动: Unregistering JMX-exposed beans on shutdown
    java把map转json
    java代码生成xml 报错:HIERARCHY_REQUEST_ERR: 尝试在不允许的位置插入节点。
    查询数据库时mapper报错:It's likely that neither a Result Type nor a Result Map was specified.
    获取session
    Apache服务器运维笔记(2)----使用apxs来进行编译安装 mod_txt 模块
    Apache服务器运维笔记(2)----使用<IfDefine>容器实现不同的配置
    Apache服务器运维笔记(1)----运行多个Apache服务器
  • 原文地址:https://www.cnblogs.com/muchengqingxin/p/13193096.html
Copyright © 2020-2023  润新知