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等技术,越来越多的服务会部署在云端.通常,我们需要需要获取日志,来进行监控.分析.预测.统计等工作,但是云端 ...
随机推荐
- 单核苷酸多态性SNP(single nucleotide polymorphism)
定义 主要指基因组水平上由单个核苷酸的变异所引起的 DNA 序列多态性. 在基因组水平上由单个核苷酸的变异所引起的DNA序列多态性.即:在不同个体的同一条染色体或同一位点的核苷酸序列中,绝大多数核苷酸 ...
- 交互程序 Scanner类
交互程序 1. Scanner类是标准Java类库的类 (1)提供一些方法用于交互式读入不同类型的输入数据,输入可以是不同的数据源,包括用户键入的数据和保存在文件中的数据(怎么弄). (2)将一个字符 ...
- MRC和ARC混编 JSONKit的使用
-fno-objc-arc 导入头文件
- 关于c++函数里面return的用法,关于调用的讲解
与下面的图片对比一下 可以看见在int b = test();d的时候cout<<"hello";就被调用了: cout<<b;只是返回return a的值 ...
- 批量注释 control+/
批量注释 control+/ You can comment and uncomment lines of code using Ctrl+斜杠.Ctrl+斜杠 comments or uncomme ...
- iOS-使用Xcode自带单元测试UnitTest
![Uploading QQ20160129-3_262826.png . . .]####什么是单元测试?一听到单元测试这个词感觉很高端,其实单元测试就是为你的方法多专门写一个测试函数.以保证你的方 ...
- Codeforces Round #605 (Div. 3) E - Nearest Opposite Parity
题目链接:http://codeforces.com/contest/1272/problem/E 题意:给定n,给定n个数a[i],对每个数输出d[i]. 对于每个i,可以移动到i+a[i]和i-a ...
- ARTS-S golang函数作为参数传递
函数作为参数传递在单元测试的时候非常有用,看下面的例子. package main import "fmt" func output(f func(string, string, ...
- C++类成员默认初始值
有时候我们会不给C++类成员变量赋初始值,或是因为忘记在构造函数中指定(C++11可以写在类内),或是觉得没有必要写.然而,因为觉得编译器会把变量赋成0而不写是错误的.本文通过C++标准来解释这个问题 ...
- poj 2955 Brackets (区间dp基础题)
We give the following inductive definition of a “regular brackets” sequence: the empty sequence is a ...