mysql级联保存_mysql数据库级联同步配置

mysql数据库级联同步配置步骤,本文以一台mysql数据库多实例3306、3307和3309为例进行配置,3306为主库,3307为从库,3309为子从库(多台单实例与一台多实例配置是一样的)

f65a0e21f98c3aa8624afb2819902b47.png

一.my.cnf文件配置

1.三个数据库实例修改my.cnf配置文件,主库3306和从库3307要打开log-bin,三个server-id不能一样

[root@mysql ~]# egrep"log-bin|server-id" /data/{3306,3307,3309}/my.cnf

/data/3306/my.cnf:log-bin =/data/3306/mysql-bin

/data/3306/my.cnf:server-id = 1

/data/3307/my.cnf:log-bin =/data/3307/mysql-bin

/data/3307/my.cnf:server-id = 3

/data/3307/my.cnf:#log-bin =/data/3309/mysql-bin

/data/3307/my.cnf:server-id = 5

2.从库3307的my.cnf文件的[mysqld]模块里添加一条内容

log-slave-updates

3.重启数据库3306、3307和3309

[root@mysql ~]#/data/3306/mysql stop

[root@mysql ~]#/data/3306/mysql start

[root@mysql ~]# /data/3307/mysqlstop

[root@mysql ~]# /data/3307/mysqlstart

[root@mysql ~]# /data/3309/mysqlstop

[root@mysql ~]# /data/3309/mysqlstart

4.进入主数据库3306,查询log_bin是否打开,server_id是多少,3307进行同样操作

[root@mysql ~]# mysql -uroot-p123456 -S /data/3306/mysql.sock

mysql> show variables like"log_bin";

+---------------+-------+

| Variable_name | Value |

+---------------+-------+

| log_bin       | ON   |

+---------------+-------+

1 row in set (0.01 sec)

mysql> show variables like"server_id";

+---------------+-------+

| Variable_name | Value |

+---------------+-------+

| server_id     | 1    |

+---------------+-------+

1 row in set (0.00 sec)

5.在主库3306上创建一个专门用来同步数据库的用户

mysql> grant replicationslave on *.* to rep@'10.0.0.%' identified by '123456';

###*.*代表所有库和所有表

mysql> flush privileges;

mysql> select user,hostmysql.user;

mysql> show grants forrep@'10.0.0.%';

二.主库3306备份数据,导入从库3307

1.在主库3306上备份数据

[root@mysql ~]# mysqldump-uroot -p123456 -S /data/3306/mysql.sock -A --events -B -x --master-data=1|gzip>/opt/$(date +%F).sql.gz

-A:所有的库    -x:全局锁表

2.将数据导入从库3307

[root@mysql ~]# ls /opt

2017-07-03.sql.gz

[root@mysql ~]# cd /opt

[root@mysql opt]# gzip -d2017-07-03.sql.gz

[root@mysql opt]# ls

2017-07-03.sql

[root@mysql opt]# mysql -uroot-p123456 -S /data/3307/mysql.sock <2017-07-03.sql

3.从库3307连接主库3306

[root@mysql opt]# mysql -uroot-p123456 -S /data/3309/mysql.sock <

CHANGE MASTER TO

MASTER_HOST='10.0.0.20',

MASTER_PORT=3307,

MASTER_USER='rep',

MASTER_PASSWORD='123456';

EOF

[root@mysql opt]# mysql -uroot-p123456 -S /data/3307/mysql.sock -e "start slave"

三.从库3307备份数据,导入从库3309,步骤同上一样

四.测试

在主库3306上创建数据库,然后再登陆3307和3309查看是否正常同步,经测试已可以正常同步了^_^

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值