环境:

Mater:   CentOS7.1  5.5.52-MariaDB  192.168.108.133

Slave:   CentOS7.1  5.5.52-MariaDB  192.168.108.140

1.导出主服务数据,将主备初始数据同步

master:

  1. //从master上导出需要同步的数据库信息
  2. mysqldump -u*** -p*** --database test > test.sql
  3. //将master上的备份信息传输到slave上
  4. scp /root/test.sql root@192.168.108.140:/opt/

slave:

  1. //进入slave的数据库
  2. mysql -u*** -p***
  3. //清空test数据库
  4. drop database test
  5. //导入master的test数据库信息
  6. source /opt/test.sql

2.配置master和slave上的mysql数据库

master:

  1. //修改master的my.cnf文件
  2. vim /etc/my.cnf
  3. //master配置如下,在[mysqld]下添加如下配置
  4. #log-bin
  5. server-id = 1
  6. log_bin = master-bin
  7. expire_logs_days = 10
  8. max_binlog_size = 100M
  9. binlog-do_db = test
  10. binlog_ignore_db = mysql
  11. //重启mysql数据库
  12. service mysqld restart
  13. //如果安装的是mariadb可以重启mariadb
  14. systemctl restart mariadb.service

slave:

  1. //修改slave的my.cnf文件
  2. vim /etc/my.cnf
  3. //slave配置如下,在[mysqld]下添加如下配置
  4. server-id = 2
  5. //重启mysql数据库
  6. service mysqld restart
  7. //如果安装的是mariadb可以重启mariadb
  8. systemctl restart mariadb.service

简单说明一下参数配置,保证主备server-id唯一。在master上需要开启mysql的binlog,log_bin=master_bin,指定binlog文件的名称。

3.创建一个复制用户,具有replication slave 权限,能保证slave能把master的数据同步过去

master:

  1. grant replication slave on *.* to \'replication\'@\'192.168.108.140\' identified by \'replication\';

4.获取master的binlog位置

master:

  1. //进入mysql数据库
  2. mysql -u*** -p***
  3. //设置读锁
  4. flush tables with read lock;
  5. //获取mysql的binlog文件信息和偏移量
  6. show master status;
  7. +-------------------+----------+--------------+------------------+
  8. | File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
  9. +-------------------+----------+--------------+------------------+
  10. | master-bin.000010 | 3713 | test | mysql |
  11. +-------------------+----------+--------------+------------------+
  12. 1 row in set (0.00 sec)
  13. //解锁
  14. unlock tables;

5.设置备端数据库

  1. //进入mysql数据库
  2. mysql -u*** -p***
  3. //停止slave
  4. stop slave;
  5. //设置对应master的binlog信息
  6. MariaDB [(none)]> change master to
  7. -> master_host=\'192.168.108.133\',
  8. -> master_user=\'replication\',
  9. -> master_password=\'replication\',
  10. -> master_log_file=\'master-bin.000010\',
  11. -> master_log_pos=3713;
  12. //启动slave
  13. start slave;

6.查看备端状态

  1. MariaDB [(none)]> show slave status\G;
  2. *************************** 1. row ***************************
  3. Slave_IO_State: Waiting for master to send event
  4. Master_Host: 192.168.108.133
  5. Master_User: replication
  6. Master_Port: 3306
  7. Connect_Retry: 60
  8. Master_Log_File: master-bin.000010
  9. Read_Master_Log_Pos: 3881
  10. Relay_Log_File: mariadb-relay-bin.000002
  11. Relay_Log_Pos: 698
  12. Relay_Master_Log_File: master-bin.000010
  13. Slave_IO_Running: Yes
  14. Slave_SQL_Running: Yes
  15. Replicate_Do_DB:
  16. Replicate_Ignore_DB:
  17. Replicate_Do_Table:
  18. Replicate_Ignore_Table:
  19. Replicate_Wild_Do_Table:
  20. Replicate_Wild_Ignore_Table:
  21. Last_Errno: 0
  22. Last_Error:
  23. Skip_Counter: 0
  24. Exec_Master_Log_Pos: 3881
  25. Relay_Log_Space: 994
  26. Until_Condition: None
  27. Until_Log_File:
  28. Until_Log_Pos: 0
  29. Master_SSL_Allowed: No
  30. Master_SSL_CA_File:
  31. Master_SSL_CA_Path:
  32. Master_SSL_Cert:
  33. Master_SSL_Cipher:
  34. Master_SSL_Key:
  35. Seconds_Behind_Master: 0
  36. Master_SSL_Verify_Server_Cert: No
  37. Last_IO_Errno: 0
  38. Last_IO_Error:
  39. Last_SQL_Errno: 0
  40. Last_SQL_Error:
  41. Replicate_Ignore_Server_Ids:
  42. Master_Server_Id: 1
  43. 1 row in set (0.00 sec)
  44. ERROR: No query specified
  1. 如果:Slave_IO_Running: Yes,Slave_SQL_Running: Yes则为配置成功,配置错误重复上面操作即可。如果解决不了可通过查看mysql日志分析处理。
  1. vim /var/log/mariadb/mariadb.log

7.测试。其实测试没啥好写的,配置成功之后直接连到主从数据库,在master上改变表、字段、数据,slave会同步变化。

写在最后:当时想的试一试能不能用mysql自带的功能做数据库灾备,后来发现mysql数据库主从同步会有一些问题。第一个不好脚本化的东西是在同步之前需保证两边的数据库初始信息一样,因为备端配置的mysql-binlog位置只是当前主数据库信息的位置,在该位置之前的数据只能通过人工导入。第二个就是mysql主从同步时,只能进行数据库的增量同步,不能进行全量同步;还有就是如果备端出现脏数据,多了一条数据,当主那边新增一条主键相同的数据,则同步失败。之后我会尝试的能不能把这些操作脚本化,发现mysql自带的同步功能限制性很大,并且手工干预的东西太多了。

版权声明:本文为jave1ove原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/jave1ove/archive/2016/12/30/6237324.html