第一种:单向主从热备
mysql主从热备有2种配置方式,备份某些库或者忽略备份某些库,建议选择后者
master机器
以下是代码片段:
vi my.cnf,添加下面的
log-bin
server-id = 1
#sql-bin-update-same
binlog-do-db=mysql //备份的数据库名,可以添加多个或者
slave机器
以下是代码片段:
log-bin
server-id = 2
#sql-bin-update-same
master-host=192.168.8.201
master-user=backup
master-password=123456
master-port=3306
master-connect-retry=10
replicate-do-db=mysql
#log-slave-updates
或者
master机器
以下是代码片段:
server-id = 1
expire-logs-days = 7
binlog-ignore-db=test
slave机器
以下是代码片段:
server-id = 2
master-host=192.168.8.201
master-user=backup
master-password=123456
master-port=3306
master-connect-retry=10
expire-logs-days = 7
replicate-ignore-db=test
在master机器上面授权:
以下是代码片段:
mysql>GRANT all ON *.* TO backup@192.168.8.202 IDENTIFIED BY "123456";
到此为止配置完成了(第一次配置需要重启mysql),剩下的工作就是再主从热备开始前保持主从的数据完全一致:
对于myisam的表,直接把master机器mysql/data目录下面的所有文件同步到slave机器对应的目录即可
对应innodb的表,不能直接同步文件,需要用mysqldump导出数据,然后在slave机器上面导入即可
注意在同步数据期间,master机器锁表成只读模式:
以下是代码片段:
mysql>flush tables with read lock;
这期间主从mysql都可以不停,数据同步完毕之后,再master机器上查看mysqlbinglog和偏移量,例如:
以下是代码片段:
mysql> show master status;
+---------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+---------------------+----------+--------------+------------------+
| mysql-bin.000012 | 4117873 | | test |
+---------------------+----------+--------------+------------------+
然后在slave机器上面修改成对应的日志文件和偏移量即可:
以下是代码片段:
mysql>slave stop;
mysql> CHANGE MASTER TO
-> MASTER_LOG_FILE=’mysql-bin.000012’,
-> MASTER_LOG_POS=4117873;
mysql>slave start;
最后master解锁:
以下是