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

背景

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

实战

  1. 首先拉取mysql的官方镜像
docker pull mysql
  1. 使用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里面。

  1. 进入到myMysql容器中
docker exec -t -i myMysql /bin/bash

-i : --interactive,交互界面。
-t : --tty,伪终端界面。

  1. 登录到myMysql容器中,登录到mysql服务器中
mysql -uroot -p 
图片.png
  1. 查询用户表信息
use mysql
select * from user\G;
图片.png

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

  1. 增加用户,授予权限
grant all on *.* to 'test'@'%' identified by '1234';

这时一条授予权限命令,当用户不存在时,则会自动创建。
. 前一个*星号代表所有数据库,后一个星号代表所有数据表
'test"@'% : test是用户名,%为所有IP。
identified by '1234' : 密码设置为1234。

  1. 退出Mysql容器
ctrl + p + q
  1. 查看myMysql容器的IP
docker inspect myMysql | grep "IPAddress"
图片.png
  1. 登录到myMysql容器的mysql服务器
mysql -h 172.17.0.4 -utest -p
图片.png
  • h : 指定主机IP
    -P : 这是指定端口的,如果你设置了自己的端口,记得加上这个参数。
    如果没有安装mysql-client(mysql服务器的连接工具),那么就先安装一下。
  1. 这时,其实数据卷已经进行了分离,还记得启动容器时我们携带的“-v”参数么。
# 在宿主机执行
ls /data/mysql
图片.png
  1. 删除容器,看数据卷是否还在
docker stop myMysql
docker rm myMysql
图片.png

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

图片.png

细节处还需深入研究

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

以上这条命令到底是咋运行的。
第一次,启动mysql容器时,宿主机的/data/mysql是空的。是docker容器中的/var/lib/mysql会自动映射到宿主机/data/mysql,让宿主机有了对应的文件信息。
第二次,我删除了docker容器,这时宿主机的/data/mysql是有文件的。然后我创建了mysql容器,并设置对应的映射关系。这时,宿主机的/data/mysql文件映射到了容器中,保持数据一致。
这就产生疑问了?到底是以哪一个为主要的数据呢?

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


    图片.png

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

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

  • 如果有的话,则判断是否是数据库文件,如果符合数据库文件系统的文件目录。那么则会使用;如果不符合数据库文件系统的文件目录,那么则会无法启动,直接报错。
  • 如果没有的话则会初始化数据库文件,生成一个干净的数据库系统并进行宿主机和docker容器间的互通。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容