Mysql主从同步备份策略的配置及常见问题

发布时间:2019-12-14编辑:脚本学堂
本文介绍下,如何配置mysql的主从同步,以及一些可能的问题与解决方法。有需要的朋友,参考下吧。

环境:
主从服务器 mysql/ target=_blank class=infotextkey>mysql数据库版本同为5.1.34
主机IP:192.168.1.1
从机IP:192.168.1.2

一. MySQL主服务器配置
1.编辑配置文件/etc/my.cnf
 

# 确保有如下行
server-id = 1
log-bin=mysql-bin
binlog-do-db=mysql  #需要备份的数据库名,如果备份多个数据库,重复设置这个选项即可
binlog-ignore-db=mysql  #不需要备份的数据库名,如果备份多个数据库,重复设置这个选项即可
log-slave-updates #这个参数一定要加上,否则不会给更新的记录些到二进制文件里
slave-skip-errors #是跳过错误,继续执行复制操作

2.建立用户
 

mysql> grant replication slave on *.* to slave@192.168.1.2 identified by ‘111111′;
# grant replication slave on *.* to ‘用户名’@'主机’ identified by ‘密码’;
# 可在Slave上做连接测试: mysql -h 192.168.1.1 -u test -p

3.锁主库表
 

mysql> FLUSH TABLES WITH READ LOCK;

4.显示主库信息
记录File和Position,从库设置将会用到
 

mysql> SHOW MASTER STATUS;
+------------------+----------+--------------+------------------+
| File             | Position | Binlog_do_db | Binlog_ignore_db |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 106      |              |                  |
+------------------+----------+--------------+------------------+
 

5.另开一个终端,打包主库
 

cd /usr/local/mysql  #mysql库目录
tar zcvf var.tar.gz var

二.MySQL从服务器配置
1、传输拿到主库数据包、解包
 

# cd /usr/local/mysql
# scp 192.168.1.1:/usr/local/mysql/var.tar.gz .
# tar zxvf var.tar.gz

2、查看修改var文件夹权限
 

# chown -R mysql:mysql var

3.编辑 /etc/my.cnf
 

server-id=2
log-bin=mysql-bin
master-host=192.168.1.1
master-user=slave
master-password=111111
master-port=3306
replicate-do-db=test  #需要备份的数据库名
replicate-ignore-db=mysql #忽略的数据库
master-connect-retry=60 #如果从服务器发现主服务器断掉,重新连接的时间差(秒)
log-slave-updates #这个参数一定要加上,否则不会给更新的记录些到二进制文件里
slave-skip-errors #是跳过错误,继续执行复制操作

4、验证连接MASTER
 

# mysql -h192.168.1.1 -uslave -ppassword
mysql> show grants for slave@192.168.1.2;

5、在SLAVE上设置同步
设置连接MASTER MASTER_LOG_FILE为主库的File,MASTER_LOG_POS为主库的Position
 

mysql> slave stop;
mysql> CHANGE MASTER TO MASTER_HOST='192.168.1.1',MASTER_USER='slave',MASTER_PASSWORD='111111',MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=106;

6、启动SLAVE服务
 

mysql> slave start;

7、查看SLAVE状态
 

mysql> SHOW SLAVE STATUSG;
 

其中 Slave_IO_Running 和 Slave_SQL_Running 两列的值都为 "Yes",表明 Slave 的 I/O 和 SQL 线程都在正常运行。

8、解锁主库表
 

mysql> UNLOCK TABLES;
 

到此主从库搭建成功。可以在主库上插入数据测试同步是否正常。