【架构】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主从的更多相关文章
- mac docker环境搭建mysql主从同步服务器
参考地址:https://www.cnblogs.com/jinjiangongzuoshi/p/9299275.html 1.下载镜像 docker pull mysql:5.7.19 2.建立配用 ...
- Docker - Docker中搭建MySQL主从
1.pull完centos7纯净版的镜像后,创建容器,然后将宿主机上下载的MySQL文件 (MySQL下载地址:http://mysql.mirror.kangaroot.net/Downloads/ ...
- win7下docker环境搭建nginx+php-fpm+easyswoole+lavarel+mysql开发环境
win7环境基础在上一篇win7下docker环境搭建nginx+php-fpm+easyswoole开发环境中已经详细叙述搭建完成 本篇文章将叙述如何在上述基础上搭建laravel开发环境,这个其实 ...
- windows环境下搭建mysql主从
参考 windows环境下mysql主从配置 1. 环境 参数 说明 主库所在的操作系统 win7 主库的版本 mysql-5.6.46-winx64 主库的ip地址 127.0.0.1 主库的端口 ...
- 怎么使用mysqlreplicate快速搭建MySQL主从呢?
用其中的mysqlreplicate工具来快速搭建MySQL主从环境. HE1:192.168.1.248 slave HE3:192.168.1.250 master 实战 Part1:安装mysq ...
- linux下搭建mysql主从
在master上创建repl账户,用于复制. grant replication slave on *.* to 'repl'@'%' identified by 'P@$$W0rd'; flush ...
- centos7系统下 docker 环境搭建
运行环境: VMware Workstation Pro 在虚拟机中安装centos7系统, 选择最小安装, 网络连接方式选择的桥接(与宿主机在同一IP段)centos7一定要安装64位, docke ...
- windows Docker Desktop 搭建mysql,mssql和redis服务
其实网上关于docker上搭建mysql的文章已经很多了,只是今晚自己搭建的时候遇到一些问题,记录一下 1.首先是pull image , docker pull mysql 2.启动服务 docke ...
- Windows环境搭建mysql服务器
Windows环境搭建mysql服务器: 1.下载mysql-installer-community-5.7.3.0-m13.2063434697并安装 安装详细步骤>> 2.安装mys ...
随机推荐
- 练习一_使用Git进行代码管理的心得
2015年9月19日,第一次软工实践课.助教给我们介绍了git,GitHub.显而易见,我并没有听懂.所以整个上午都在找教程,一个字一个字对着敲,然后敲着敲着就出错,回宿舍,继续敲,也是一样的... ...
- 使用 ArcGIS中的ArcObjects进行二次开发
参考网址:https://blogs.esri.com/esri/arcgis/2012/12/07/arcobjects-or-runtime-sdk/ http://resources.arcgi ...
- Linux进程管理工具——supervisor
介绍 Supervisord是用Python实现的一款非常实用的进程管理工具 安装 这里用源码 supervisor-.tar.gz .tar.gz cd supervisor- sudo pytho ...
- WCF学习(二)对控件简单了解以及4个文本控件的简介
WPF基础控件 系统默认提供的基础控件: 文本控件介绍与用法 Label控件 label控件:一般用户描述性文字显示. 在Label控件使用时,一般给予用户提示.用法上没有什么很特殊的,label控件 ...
- 图解Android - System Service 概论 和 Android GUI 系统
通过 图解Android - Binder 和 Service 一文中,我们已经分析了Binder 和 Service的工作原理.接下来,我们来简要分析Android 系统里面都有哪些重要的Servi ...
- href的参数含有中文在IE下乱码的解决
这是在使用kendo grid的自定义链接时遇到的一个坑,链接如下: var TempStr = "<a href='" + Url.Action("EditUse ...
- 2.Android之按钮Button和编辑框EditText学习
今天学习android一些基本控件:button和edittext使用,我们平时网页或者手机登录一般都会有登录框,这里面就用到这两个部件. 如图: 所对应XML文件: 一般第二个编辑框都是输入密码,所 ...
- 【BZOJ-2295】我爱你啊 暴力
2295: [POJ Challenge]我爱你啊 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 202 Solved: 141[Submit][St ...
- 【蒟蒻の进阶PLAN】 置顶+持续连载
看到周围神犇们纷纷列计划,本蒟蒻也决定跟随他们的步伐,计划大约是周计划吧,具体怎么安排我也不确定.. 2015.12.30 刚刚学习完最基础的网络流,需要进行这方面的练习,从简到难,有空余的话尝试学习 ...
- HYSBZ - 2152 聪聪和可可
Description 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是他们家只有一台电脑)……遇到这种问题,一般情况下石头剪刀布就好 ...