docker mysql 数据_使用Docker快速搭建Mysql,并进行数据卷分离

背景

昨天笔者完成了Docker快速搭建Nginx+PHP-FPM环境,今天趁着没事,继续搭建LNMP+REDIS的环境。有了昨天的思路,今天花了一点点时间,就搞定了Mysql的搭建以及使用,并将Mysql的数据卷进行了分离。

实战

首先拉取mysql的官方镜像

docker pull mysql

使用mysql镜像运行单独的容器

docker run -d --name myMysql -v /data/mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -p 3306:3306 mysql

-d : --detach,后台运行。

--name : 为你的镜像创建一个别名,该别名用于更好操作。

-p : 映射端口,一般我们会将默认端口进行更改,避免与本机的mysql端口冲突,如果你宿主机有mysql,请更改端口,如 -p 33060:3306。

-e : 环境变量。为mysql的root用户设置密码为123456。

-v : 指定数据卷,意思就是将mysql容器中的/var/lib/mysql(这个是数据库所有数据信息文件)映射到宿主机/data/mysql里面。

进入到myMysql容器中

docker exec -t -i myMysql /bin/bash

-i : --interactive,交互界面。

-t : --tty,伪终端界面。

登录到myMysql容器中,登录到mysql服务器中

mysql -uroot -p

57420240e877

图片.png

查询用户表信息

use mysql

select * from user\G;

57420240e877

图片.png

发现一个问题,只能通过localhost进行连接,通过其它渠道是无法进行连接的。所以这时我们就需要进行修改HOST字段为所有IP均可以访问,但明显,一个明智的DBA(Database Administrator)不会这么做的。所以,为了简单,我们增加一个用户,并给其对应的权限。

增加用户,授予权限

grant all on *.* to 'test'@'%' identified by '1234';

这时一条授予权限命令,当用户不存在时,则会自动创建。

. 前一个*星号代表所有数据库,后一个星号代表所有数据表

'test"@'% : test是用户名,%为所有IP。

identified by '1234' : 密码设置为1234。

退出Mysql容器

ctrl + p + q

查看myMysql容器的IP

docker inspect myMysql | grep "IPAddress"

57420240e877

图片.png

登录到myMysql容器的mysql服务器

mysql -h 172.17.0.4 -utest -p

57420240e877

图片.png

h : 指定主机IP

-P : 这是指定端口的,如果你设置了自己的端口,记得加上这个参数。

如果没有安装mysql-client(mysql服务器的连接工具),那么就先安装一下。

这时,其实数据卷已经进行了分离,还记得启动容器时我们携带的“-v”参数么。

# 在宿主机执行

ls /data/mysql

57420240e877

图片.png

删除容器,看数据卷是否还在

docker stop myMysql

docker rm myMysql

57420240e877

图片.png

依然还在,这说明如果我们创建新的mysql容器,那么只需要指定数据卷就可以了。

57420240e877

图片.png

细节处还需深入研究

docker -v /data/mysql:/var/lib/mysql

以上这条命令到底是咋运行的。

第一次,启动mysql容器时,宿主机的/data/mysql是空的。是docker容器中的/var/lib/mysql会自动映射到宿主机/data/mysql,让宿主机有了对应的文件信息。

第二次,我删除了docker容器,这时宿主机的/data/mysql是有文件的。然后我创建了mysql容器,并设置对应的映射关系。这时,宿主机的/data/mysql文件映射到了容器中,保持数据一致。

这就产生疑问了?到底是以哪一个为主要的数据呢?

开始做个实验,重新创建目录,在目录中添加一个demo文件,使用其进行挂在数据卷,看是否会以宿主机为主要数据。

57420240e877

图片.png

可以看到,启动都无法启动。报了一个错误:initialize specified but the data directory has files in it。Aborting。其含义为初始化数据库文件时,但里面有一个文件,被拒绝。

总结

基本上可以了解为这样一个流程,当指定-v参数时,在启动容器时会首先检查宿主机中是否有数据文件:

如果有的话,则判断是否是数据库文件,如果符合数据库文件系统的文件目录。那么则会使用;如果不符合数据库文件系统的文件目录,那么则会无法启动,直接报错。

如果没有的话则会初始化数据库文件,生成一个干净的数据库系统并进行宿主机和docker容器间的互通。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值