上一篇是代码层次读写分离,这里是配置好数据库集群

搭建一主多从数据库集群

主从备份需要多台虚拟机,我是用wmware完整克隆多个实例,注意直接克隆的虚拟机会导致每个数据库的uuid相同,需要修改为不同的uuid。修改方法参考这个:点击跳转

注意:

(1)linxu下mysql文件查找

查看mysql启动时读取配置文件的默认目录
命令 

mysql --help|grep 'my.cnf'

输出

order of preference, my.cnf, $MYSQL_TCP_PORT,
/etc/my.cnf /etc/mysql/my.cnf /usr/local/etc/my.cnf ~/.my.cnf
/etc/my.cnf, /etc/mysql/my.cnf, /usr/local/etc/my.cnf, ~/.my.cnf 

这些就是mysql默认会搜寻my.cnf的目录,顺序排前的优先。

(2)主从复制一定要尽量保持mysql版本一致,如果不一致,一定要低版本作为master,高版本为slave。

(3)如果中途操作导致主从复制错误,可重新建立联系后保持正常。

 

 

 

主库配置

主数据库(master)中新建一个用户用于从数据库(slave)读取主数据库二进制日志,sql语句如下:

?

1

2

3

mysql> CREATE USER 'repl'@'%' IDENTIFIED BY '123456';#创建用户

 mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';#分配权限

 mysql>flush privileges; #刷新权限

同时修改mysql配置文件开启二进制日志,新增部分如下:

?

1

2

3

4

[mysqld]

server-id=1

log-bin=master-bin

log-bin-index=master-bin.index

然后重启数据库,使用show master status;语句查看主库状态,如下所示:

从库配置

这里可能出现mysql版本不一致

【解决方案】:
 直接在master上执行,即可:

  1. mysql> SET GLOBAL binlog_checksum=none;

当然也要加到配置文件的[mysqld]中,避免重启失效:
 

  1. [mysqld]
  2. binlog-checksum = none

 

 

同样先新增几行配置:

?

1

2

3

4

[mysqld]

server-id=2

relay-log-index=slave-relay-bin.index

relay-log=slave-relay-bin

然后重启数据库,使用如下语句连接主库:

?

1

2

3

4

5

6

CHANGE MASTER TO

 MASTER_HOST='192.168.226.5',

 MASTER_USER='root',

 MASTER_PASSWORD='123456',

 MASTER_LOG_FILE='master-bin.000003',

 MASTER_LOG_POS=154;

接着运行start slave;开启备份,正常情况如下图所示:Slave_IO_Running和Slave_SQL_Running都为yes。

可以用这个步骤开启多个从库。

  默认情况下备份是主库的全部操作都会备份到从库,实际可能需要忽略某些库,可以在主库中增加如下配置:

?

1

2

3

4

5

6

7

# 不同步哪些数据库

binlog-ignore-db = mysql

binlog-ignore-db = test

binlog-ignore-db = information_schema

  

# 只同步哪些数据库,除此之外,其他不同步

binlog-do-db = game

转载于:https://my.oschina.net/u/3685890/blog/3005441

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值