主从工做原理:mysql
配置介绍:sql
MASTER:172.17.0.2数据库
SLAVE:172.17.0.3vim
MASTER内数据库:服务器
仅仅同步以上两个库(在configerdata库中建立了wu2表)测试
SLAVE库:spa
空空如也线程
一、将MASTER库的数据库导入到SLAVE库中3d
(1)使用mysqldump备份MASTER库rest
备份前最好将服务中止,防止有数据在设置过程当中写入
#将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,导入成功
二、修改MySQL配置文件使用bin-log进行同步
(1)通常在配置文件是/etc/my.cnf,个人是apt-get装,因此位置不一样
vim /etc/mysql/mysql.conf.d/mysqld.cnf
在mysqld参数下添加:
log-bin = mysql-bin server-id =1 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 'fan1'; #在SLAVE中建立在MASTER有全部特殊权限的用户
FLUSH PRIVILEGES; #刷新权限
(3)前往SLAVE主机测试登陆刚刚建立的用户
显示没法链接,可是网是通的
问题在于MASTER配置文件中限制了其余主机登陆,修改如下配置重启便可:
如今链接:
ok,链接成功
三、从节点配置访问主节点的参数信息
(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=594;
特别注意:MASTER_LOG_FILE= 、MASTER_LOG_POS= 必须和MASTER一致
查看SLAVE状态,已经同步成功
开启SLAVE线程:
四、测试数据是否同步
在MASTER中添加数据
进SLAVE库中查有无同步
ok,已同步。