怎么在docker上搭建mysql的主从
来源:SegmentFault
时间:2023-01-11 13:49:18 301浏览 收藏
积累知识,胜过积蓄金银!毕竟在##column_title##开发的过程中,会遇到各种各样的问题,往往都是一些细节知识点还没有掌握好而导致的,因此基础知识点的积累是很重要的。下面本文《怎么在docker上搭建mysql的主从》,就带大家讲解一下MySQL、docker、MySQL主从知识点,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~
序
本文主要研究怎么在docker上搭建mysql的主从。因为在单机搭建mysql多实例然后再配主从,感觉太痛苦了,环境各有不同,配置各不大相同,从网上找搭建方法,试了半天也没成功,最后也没耐心调试下去了,浪费了好多时间。觉得还是应该用先进的技术来避免这种时间的浪费,正好docker可以用上。
搭好的镜像
google到tutum搭建好的mysql的docker镜像,关键的是人家也帮你弄好了主从的命令。
git clone https://github.com/tutumcloud/mysql.git
根据Dockerfile构建镜像
docker build -t xixicat/mysql5.6 5.6/ ...... Step 6 : ADD import_sql.sh /import_sql.sh ---> 8e105223fa8b Removing intermediate container add786317f4a Step 7 : ADD run.sh /run.sh ---> 6d3e93df4d46 Removing intermediate container 9d959e1f9684 Step 8 : ENV MYSQL_USER admin MYSQL_PASS **Random** ON_CREATE_DB **False** REPLICATION_MASTER **False** REPLICATION_SLAVE **False** REPLICATION_USER replica REPLICATION_PASS replica ON_CREATE_DB **False** ---> Running in 8d4857d7bf16 ---> 1329735e7b3a Removing intermediate container 8d4857d7bf16 Step 9 : VOLUME /etc/mysql /var/lib/mysql ---> Running in 1e654949edf5 ---> 2c88ab58a842 Removing intermediate container 1e654949edf5 Step 10 : EXPOSE 3306 ---> Running in f349784d176a ---> 412c34a688cf Removing intermediate container f349784d176a Step 11 : CMD /run.sh ---> Running in 5d81fa8627e2 ---> ccdd6bddfcf1 Removing intermediate container 5d81fa8627e2 Successfully built ccdd6bddfcf1
其中-t参数为给镜像贴个标签"xixicat/mysql",后面的参数为Dockerfile文件所在的文件夹的路径
查看镜像
➜ docker-mysql git:(master) ✗ docker images REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE xixicat/mysql5.6 latest 0dbd5f7ff4c0 About a minute ago 471.8 MB xixicat/mysql latest ccdd6bddfcf1 3 hours ago 317.8 MB ubuntu 14.04 c4bea91afef3 13 days ago 187.9 MB ubuntu trusty c4bea91afef3 13 days ago 187.9 MB
启动容器
启动master
docker run -d -e REPLICATION_MASTER=true -e REPLICATION_PASS=admin -e MYSQL_PASS=admin -e MYSQL_USER=admin -p 3307:3307 -v /Users/xixicat/devtool/docker-mysql/5.5/data/master:/var/lib/mysql --name mysql xixicat/mysql5.6
参数解释:
-d,表示Detached mode,后台运行
-t,让Docker分配一个伪终端(pseudo-tty)并绑定到容器的标准输入上
-i,让容器的标准输入保持打开,可以-it配合用,与-d相对应
-e,表示传入的环境变量
-p,表示暴露的端口,即本机端口与docker端口映射
-v,表示挂载文件,这里挂载了本地的文件夹到docker的文件夹
--name,表示给容器起的名字,方便查看,若要配置主从,这里需要指定为mysql,我表示已经采坑。
启动后查看容器:
~ docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 66dbc9aa02d4 xixicat/mysql5.6 "/run.sh" 3 seconds ago Up 2 seconds 3306/tcp, 0.0.0.0:3307->3307/tcp mysql
登陆mysql:
mysql -uadmin -P3307
删除容器(
docker ps -a docker stop masterDb docker rm masterDb
查看启动logs(
docker logs masterDb
启动slave
docker run -d -e REPLICATION_SLAVE=true -e MYSQL_PASS=admin -e MYSQL_USER=admin -p 3308:3308 -v /Users/xixicat/devtool/docker-mysql/5.6/data/slave:/var/lib/mysql --name slaveDb --link mysql:mysql xixicat/mysql5.6
参数解释:
--link,该参数的格式为--link name:alias,其中name是要链接的容器的名称,alias是这个连接的别名,若要创建主从这里也指定为mysql:mysql,表示已经采坑。
查看容器:
master git:(master) docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 04fed79e8787 xixicat/mysql "/run.sh" 3 seconds ago Up 3 seconds 3306/tcp, 0.0.0.0:3308->3308/tcp slaveDb 66dbc9aa02d4 xixicat/mysql "/run.sh" 6 minutes ago Up 27 seconds 3306/tcp, 0.0.0.0:3307->3307/tcp mysql
登陆看看:
mysql -uadmin -P3308
遇到的错误
症状
容器启动一阵子就自动关闭了,然后去docker logs mysql查看日志,发现错误:
160118 15:08:57 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql 160118 15:08:57 [Warning] Using unique option prefix key_buffer instead of key_buffer_size is deprecated and will be removed in a future release. Please use the full name instead. 160118 15:08:57 [Note] /usr/sbin/mysqld (mysqld 5.5.46-0ubuntu0.14.04.2-log) starting as process 523 ... 160118 15:08:57 [Warning] Setting lower_case_table_names=2 because file system for /var/lib/mysql/ is case insensitive /usr/sbin/mysqld: File './mysql-bin.index' not found (Errcode: 13) 160118 15:08:57 [ERROR] Aborting 160118 15:08:57 [Note] /usr/sbin/mysqld: Shutdown complete 160118 15:08:57 mysqld_safe mysqld from pid file /var/run/mysqld/mysqld.pid ended
重点关注这一行:
/usr/sbin/mysqld: File './mysql-bin.index' not found (Errcode: 13)
解决
可能是文件权限的问题,去查看数据库根目录的权限
docker exec -it mysql /bin/sh # ls -l /var/lib/mysql total 0 drwxr-xr-x 1 1000 staff 68 Jan 18 14:23 mysql
参数详解:
第一列:“drwxr-xr-x” 表示文件的类型和文件权限
第二列:“1”是纯数字 ,表示文件链接个数
第三列:表示文件的所有者
第四列:所属的组
第五列:“68”,表示为文件长度(大小)
第六列:“Jan 18 14:23”,表示文件最后更新(修改)时间
第七列:“mysql” 表示文件的名称
但是,这里是挂载本地文件,于是修改挂载的本地文件夹权限
cd /Users/xixicat/devtool/docker-mysql/5.6/data sudo chown -R mysql:mysql *
仍然报错
2016-01-18 17:26:23 988 [ERROR] InnoDB: ./ibdata1 can't be opened in read-write mode
于是各种尝试,都没有成功,还是先把-v参数去掉了...
踩过的坑
终于介绍完啦!小伙伴们,这篇关于《怎么在docker上搭建mysql的主从》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布数据库相关知识,快来关注吧!
-
499 收藏
-
160 收藏
-
105 收藏
-
244 收藏
-
235 收藏
-
317 收藏
-
371 收藏
-
244 收藏
-
288 收藏
-
480 收藏
-
430 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习
-
- 碧蓝的枕头
- 这篇技术贴太及时了,up主加油!
- 2023-03-31 19:55:24
-
- 潇洒的黑猫
- 这篇技术贴真及时,太全面了,很有用,已加入收藏夹了,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-03-25 00:12:35
-
- 灵巧的电灯胆
- 很棒,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢楼主分享文章!
- 2023-03-17 04:07:35
-
- 着急的蜡烛
- 好细啊,已收藏,感谢up主的这篇技术贴,我会继续支持!
- 2023-03-12 18:46:52
-
- 慈祥的狗
- 真优秀,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢师傅分享技术文章!
- 2023-03-03 20:57:46
-
- 热情的春天
- 这篇博文真是及时雨啊,太全面了,写的不错,mark,关注作者了!希望作者能多写数据库相关的文章。
- 2023-03-03 14:54:24
-
- 高高的板栗
- 细节满满,码住,感谢博主的这篇博文,我会继续支持!
- 2023-01-23 12:42:31
-
- 糊涂的苗条
- 太全面了,码起来,感谢师傅的这篇技术文章,我会继续支持!
- 2023-01-23 11:24:58
-
- 明理的犀牛
- 这篇文章内容真是及时雨啊,太详细了,受益颇多,已收藏,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-01-17 21:05:54
-
- 苗条的金针菇
- 这篇文章内容真是及时雨啊,师傅加油!
- 2023-01-17 00:20:29
-
- 追寻的红牛
- 很有用,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢up主分享文章内容!
- 2023-01-16 05:50:57
-
- 体贴的世界
- 这篇技术贴真是及时雨啊,太详细了,感谢大佬分享,收藏了,关注博主了!希望博主能多写数据库相关的文章。
- 2023-01-15 20:07:30
-
- 追寻的犀牛
- 写的不错,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢老哥分享技术贴!
- 2023-01-14 14:53:55
-
- 拉长的鲜花
- 这篇文章内容真及时,太全面了,感谢大佬分享,码住,关注楼主了!希望楼主能多写数据库相关的文章。
- 2023-01-12 18:23:26
-
- 光亮的滑板
- 受益颇多,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢作者分享文章!
- 2023-01-12 01:44:50