mariadb主从部署

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mariadb主从部署相关的知识,希望对你有一定的参考价值。

MariaDB主从服务器优点简介

辅组实现备份Replication

高可用:在主服务器出现异常情况,修改指定配置可以直接顶替主服务器。

异地容灾

Scale out:分摊负载(是否启用!)

一、部署文档

1.确保在主服务器和从服务器上安装的MariaDB版本一致.

2.在主服务器上为从服务器设置一个连接账户

MariaDB [(none)]> GRANT REPLICATION SLAVE, SUPER, RELOAD ON *.* TO ‘‘@‘ IDENTIFIED BY ‘。

主服务器IP:

从服务器IP:

1.确保在主服务器和从服务器上安装的MariaDB版本一致.

2.在主服务器上为从服务器设置一个连接账户

MariaDB[(none)]> GRANT REPLICATION SLAVE, SUPER, RELOAD ON *.* TO IDENTIF IED BY ‘userpassword‘; 

3. 执行FLUSH TABLES WITH READ LOCK 进行

MariaDB [(none)]> FLUSH TABLES WITH READ LOCK 

4. 让客户程序保持运行,发出FLUSH TABLES语句让读锁定保持有效。(如果退出客户程序,锁被释放)。进入主服务器的数据目录,然后执行备份命令

读取主服务器上当前的二进制日志名(File)和偏移量值(Position),并记录下来:

MariaDB [(none)]> SHOW MASTER STATUS;取得快照并记录日志名和偏移量后,可以在主服务器上重新启用写活动:

MariaDB [(none)]>UNLOCK TABLES;

5. 确保主服务器主机上my.cnf文件的[mysqld]部分包括一个log_bin选项,并修改名称为master-bin  

6. 停止用于从服务器的服务器并在其my.cnf文件中修改server-id-11

7.如果对主服务器的数据进行二进制备份,启动从服务器之前将它复制到从服务器的数据目录中。

确保对这些文件和目录的权限正确。服务器 MySQL运行的用户必须能够读写文件,如同在主服务器上一样。这里我们使用root用户操作

8. 用--skip-slave-start选项启动从服务器,以便它不立即尝试连接主服务器。

9. 在从服务器上执行下面的语句:

   MariaDB[(none)]> CHANGE MASTER TO MASTER_HOST=‘‘,MASTER_USER=‘‘,MASTER_PASSWORD‘‘,         

MASTER_LOG_FILE=‘‘,MASTER_LOG_POS=; 

9. 启动从服务器线程:

MariaDB [(none)]> START SLAVE;

10.验证部署是否成功

1. MariaDB [(none)]> show slave status\G  

2.  

3. *************************** 1. row ***************************  

4.  

5. Slave_IO_State: Waiting for master to send event  

6.  

7. Master_Host: 

8.  

9. Master_User: rep_slave  

10.  

11. Master_Port: 3306  

12.  

13. Connect_Retry: 60  

14.  

15. Master_Log_File: mysql-bin.000058  

16.  

17. Read_Master_Log_Pos: 27324573  

18.  

19. Relay_Log_File: cacti-11-111-relay-bin.000008  

20.  

21. Relay_Log_Pos: 27324718  

22.  

23. Relay_Master_Log_File: mysql-bin.000058  

24.  

25. Slave_IO_Running: Yes  

26.  

27. Slave_SQL_Running: Yes  

28.  

29. Replicate_Do_DB:  

30.  

31. Replicate_Ignore_DB: mysql  

32.  

33. Replicate_Do_Table:  

34.  

35. Replicate_Ignore_Table:  

36.  

37. Replicate_Wild_Do_Table:  

38.  

39. Replicate_Wild_Ignore_Table:  

40.  

41. Last_Errno: 0  

42.  

43. Last_Error:  

44.  

45. Skip_Counter: 0  

46.  

47. Exec_Master_Log_Pos: 27324573  

48.  

49. Relay_Log_Space: 27325025  

50.  

51. Until_Condition: None  

52.  

53. Until_Log_File:  

54.  

55. Until_Log_Pos: 0  

56.  

57. Master_SSL_Allowed: No  

58.  

59. Master_SSL_CA_File:  

60.  

61. Master_SSL_CA_Path:  

62.  

63. Master_SSL_Cert:  

64.  

65. Master_SSL_Cipher:  

66.  

67. Master_SSL_Key:  

68.  

69. Seconds_Behind_Master: 0  

70.  

71. Master_SSL_Verify_Server_Cert: No  

72.  

73. 1 row in set (0.00 sec) 

当Slave_IO_Running和Slave_SQL_Running都显示Yes的时候,表示同步成功。

二配置优化从服务器使其重启后自动启动复制进程

修改配置文件my.cnf:

从服务器添加read-only = ON 重启MarianDB

主服务器添加sync-binlog = ON 用于事物安全

 


本文出自 “扑克脸” 博客,请务必保留此出处http://lirenpgood.blog.51cto.com/9747573/1775283

以上是关于mariadb主从部署的主要内容,如果未能解决你的问题,请参考以下文章

5分钟了解与部署mariaDB(mysql)主从复制

使用python3脚本部署mariadb主从架构

初识MariaDB之5——主从复制原理及部署

MySQL(mariadb)多实例应用与多实例主从复制

MySQL(mariadb)多实例应用与多实例主从复制

Linux7/Centos7 Mariadb主从配置过程