MySQL主从复制配置(Docker容器内配置)
主从工作原理:

配置介绍:
MASTER:172.17.0.2
SLAVE:172.17.0.3
MASTER内数据库:

仅仅同步以上两个库(在configerdata库中创建了wu2表)
SLAVE库:

空空如也
1、将MASTER库的数据库导入到SLAVE库中
(1)使用mysqldump备份MASTER库
备份前最好将服务停止,防止有数据在设置过程中写入
#将configerdata userdata两个库的结构与数据全部备份到/root/baksql.sql中
mysqldump -h 127.0.0.1 -uroot -proot1 --databases configerdata userdata > /root/baksql.sql --all-databases #备份所有的数据库
--databases #备份指定库,多个库用空格隔开
--database 数据库名 表1 表2 #备份指定库的表,多个表用空格隔开
--database 库名 | gzip #备份库时进行压缩
mysqldump -h 127.0.0.1 -uroot -proot1 --databases configerdata userdata > /root/baksql.sql

(2)将导出的库文件传输到SLAVE中(scp、lrzsz均可)

(3)将.sql文件导入到SLAVE数据库中
进入输入库,执行:
source /root/baksql.sql

查看SLAVE库内有无MASTER中的表

ok,导入成功
2、修改MySQL配置文件使用bin-log进行同步
(1)一般在配置文件是/etc/my.cnf,我的是apt-get装,所以位置不同
vim /etc/mysql/mysql.conf.d/mysqld.cnf
在mysqld参数下添加:
log-bin = mysql-bin
server-id = replicate-do-db=configerdata #指定同步的数据库(若需将所有数据库同步,则不需加此配置项)
replicate-do-db=userdata #指定同步的数据库
#replicate-ignore-db=mysql 此配置为指定不同步的数据库

service mysql restart #重启mysql
(2)进入MASTER mysql中,创建用于SLAVE的用户
GRANT ALL ON *.* TO liu@172.17.0.3 IDENTIFIED BY 'liu1'; #赋予liu用户所有数据库所有权限
GRANT ALL PRIVILEGES ON *.* TO fan@172.17.0.3 IDENTIFIED BY 'fan'; #在SLAVE中创建在MASTER有所有特殊权限的用户
FLUSH PRIVILEGES; #刷新权限

(3)前往SLAVE主机测试登录刚刚创建的用户

显示无法连接,但是网是通的
问题在于MASTER配置文件中限制了其他主机登录,修改以下配置重启即可:

现在连接:

ok,连接成功
3、从节点配置访问主节点的参数信息
(1)首先编辑从机配置文件,添加如下配置:
server-id=2

service mysql restart #重启mysql
(2)赋予权限
查看主服务器的节点
show master status\G;

在从服务中配置:
首先关闭SLAVE线程;STOP SLAVE;
然后再执行:
CHANGE MASTER TO MASTER_HOST='172.17.0.2',MASTER_USER='fan',MASTER_PASSWORD='fan1', MASTER_LOG_FILE='mysql-bin.000002',MASTER_LOG_POS=;
特别注意:MASTER_LOG_FILE= 、MASTER_LOG_POS= 必须和MASTER一致

查看SLAVE状态,已经同步成功

开启SLAVE线程:

4、测试数据是否同步
在MASTER中添加数据

进SLAVE库中查有无同步

ok,已同步。
如有转载请标明出处 谢谢
MySQL主从复制配置(Docker容器内配置)的更多相关文章
- Docker 容器内配置Tomcat manager 远程控制
下载tomcat镜像 , docker run it docker exec -ti 容器ID /bin/bash 进入容器 apt-get update , apt-get install vi ...
- Docker容器内Mysql大小写敏感方案解决
Docker容器内Mysql大小写敏感方案解决 一.(lower_case_table_names)参数说明 二.Docker 部署 MySql 并修改为大小写不敏感 2.1直接在Docker启动的时 ...
- Docker容器内连接宿主机即CentOS的Mysql服务器
docker的宿主机是虚拟机下的CentOS 博主最近遇到一种情况,从服务器拷贝了一份数据库在宿主机Mysql服务器上,想要用本地的数据库测试自己的代码正确性,但是项目程序都是靠docker一键部署的 ...
- Docker容器网络配置
Docker容器网络配置 1.Linux内核实现名称空间的创建 1.1 ip netns命令 可以借助ip netns命令来完成对 Network Namespace 的各种操作.ip netns命令 ...
- 配置docker容器上ssh无密登录
配置docker容器上ssh无密登录 1.修改所有容器中root账户密码 ssh到远程主机时,首次需要密码访问,因此需要修改root账号密码. 密码必须要8位以上字母数字混合. $>passwd ...
- Docker容器安装配置SQLServer服务(Linux)
一:前言 随着不断的对Docker容器的实践和学习,越来越觉得容器的强大,把 SQL Server 数据库服务放在docker容器中,比你自己在宿主服务器上面安装配置一个SQL Server服务器是要 ...
- 记录一次docker容器内修改my.cnf配置文件max_allowed_packet参数的过程
1. 问题背景 在一次新版本功能开发完毕,配合测试的过程中,测试反馈某个XxlJob定时任务一直执行失败,在分析了日志之后,找到了报错的原因: Packet for query is too larg ...
- Jenkins(Docker容器内)使用宿主机的docker命令
1.Jenkins镜像 Docker容器内的Jenkins使用容器外宿主机的Docker(即DooD,还有另外的情况就是DioD),google一下有几种说法,但是都没试成功(试过一种就是修改宿主机/ ...
- Flume+Kafka收集Docker容器内分布式日志应用实践
1 背景和问题 随着云计算.PaaS平台的普及,虚拟化.容器化等技术的应用,例如Docker等技术,越来越多的服务会部署在云端.通常,我们需要需要获取日志,来进行监控.分析.预测.统计等工作,但是云端 ...
随机推荐
- 在vue中使用基于d3为基础的dagre-d3.js搞定一个流程图组件
项目中想搞定一个流程图,开始使用了阿里的G6,但是G6目前不支持手势,这样就很郁闷了,因为公司的领导都是使用iPad看的,你不支持手势是不行的,后来又想到了百度的echarts,试了试,感觉还不错,手 ...
- 前端工具-定制ESLint 插件以及了解ESLint的运行原理
这篇文章目的是介绍如何创建一个ESLint插件和创建一个ESLint rule,用以帮助我们更深入的理解ESLint的运行原理,并且在有必要时可以根据需求创建出一个完美满足自己需求的Lint规则. 插 ...
- Python开发GUI工具介绍,实战:将图片转化为素描画!
欢迎添加华为云小助手微信(微信号:HWCloud002 或 HWCloud003),输入关键字"加群",加入华为云线上技术讨论群:输入关键字"最新活动",获取华 ...
- Python一秒搭建ftp服务器,帮助你在局域网共享文件
"老板 来碗面" "要啥面?" "内牛满面.." 最近项目上的事情弄得人心累,本来是帮着兄弟项目写套入口代码,搞着搞着就被拉着入坑了.搞开发 ...
- iOS开发之UIWebView
转自:http://www.cnblogs.com/zhuqil/archive/2011/07/28/2119923.html UIWebView是iOS sdk中一个最常用的控件.是内置的浏览器控 ...
- 2018 牛客国庆集训派对Day4 - H 树链博弈
链接:https://ac.nowcoder.com/acm/contest/204/H来源:牛客网 题目描述 给定一棵 n 个点的树,其中 1 号结点是根,每个结点要么是黑色要么是白色 现在小 Bo ...
- HDU1848 Fibonacci again and again(SG 函数)
任何一个大学生对菲波那契数列(Fibonacci numbers)应该都不会陌生,它是这样定义的: F(1)=1; F(2)=2; F(n)=F(n-1)+F(n-2)(n>=3); 所以,1, ...
- 简述c和c++的基本区别,你真的懂吗?(面试必学)
前言本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:angry_youth **1.c和c++的头文件不同:** c的头 ...
- matlab安装出现“无法访问所在网络位置”的正确解决办法
今天安装matlab时出现了如下错误:无法访问您试图使用的功能所在的网络位置,单击"确认"重试或者在下面输入包含"vcredist.msc"的文件夹路径. (由 ...
- 【Babel】293- 初学 Babel 工作原理
戳蓝字「前端技术优选」关注我们哦! 前言 babel Babel 对于前端开发者来说应该是很熟悉了,日常开发中基本上是离不开它的. 已经9102了,我们已经能够熟练地使用 es2015+ 的语法.但是 ...