搭建一主多从数据库集群
主从备份需要多台虚拟机,我是用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配置文件开启二进制日志,新增部分如下:
1 2 3 4 |
|
然后重启数据库,使用show master status;
语句查看主库状态,如下所示:
从库配置
这里可能出现mysql版本不一致
【解决方案】:
直接在master上执行,即可:
- mysql> SET GLOBAL binlog_checksum=none;
当然也要加到配置文件的[mysqld]中,避免重启失效:
- [mysqld]
- binlog-checksum = none
同样先新增几行配置:
1 2 3 4 |
|
然后重启数据库,使用如下语句连接主库:
1 2 3 4 5 6 |
|
接着运行start slave;
开启备份,正常情况如下图所示:Slave_IO_Running和Slave_SQL_Running都为yes。
可以用这个步骤开启多个从库。
默认情况下备份是主库的全部操作都会备份到从库,实际可能需要忽略某些库,可以在主库中增加如下配置:
1 2 3 4 5 6 7 |
|