Linux(3)—— Centos7.8下实现MySQL5.7主主互备

    技术2026-04-03  16

    Centos7.8下实现MySQL5.7主主互备

    Mysql的三种复制模式Mysql主从解决的问题Mysql主从复制的原理Mysql主主互备搭建环境添加同步用户以及分配权限修改配置文件/etc/my.cnf查看master状态并把自己当作从服务器指向对方为主服务器启动从服务器测试

      Mysql主主互备是在基于主从备份的基础上,从节点也是主节点,实现两者互相以对方为参考系实现rsync操作。

    Mysql的三种复制模式

    1、基于语句的复制,主服务器上执行的SQL语句在从服务器上同样执行;

    2、基于行的复制,把改变的内容复制过去,而不是把命令在服务器上执行一遍;

    3、混合类型复制,默认基于语句的复制,一旦发现语句无法精确复制的时候采用基于行的复制。

    Mysql主从解决的问题

    1、负载均衡,当我们一个集群多个从节点时,可通过第三方技术,例如LVS实现负载均衡;

    2、数据备份,当主节点发生数据的改变时,从节点自动备份保证数据安全

    3、高可用性和容错性

    4、读写分离

    Mysql主从复制的原理

      Master服务器数据发生改变时,Master服务器将改变的记录写入二进制binlog日志中>>Slave服务器定时探测其日志文件是否发生改变,若改变>>Slave服务器开始I/O Thread请求Master服务器的二进制事件>>主节点为每个I/O线程启动一个Dump线程,向Slave服务器发送二进制事件,并保存在从节点本地的中继日志中>>从节点启动SQL Thread从中继日志中读取二进制日志>>Slave节点重放二进制日志,实现数据同步>>I/O Thread和SQL Thread进入睡眠等待唤醒。

    Mysql主主互备搭建

      在两台安装了Mysql的环境下进行,值得注意的是,一般只要跟同步相关的操作几乎都需要NTP实现时间同步。

    环境

    操作系统:centos7.8 2003

    Master1:192.168.2.21 heetok.learning.com

    Master2:192.168.2.22 heetok2.learning.com

    已安装NTP、Mysql

    添加同步用户以及分配权限

    #all-nodes CREATE USER 'replication'@'%' IDENTIFIED BY 'Replication@1'; GRANT REPLICATION SLAVE ON *.* TO 'replication'@'%';

    修改配置文件/etc/my.cnf

    #all-nodes [mysqld] datadir=/var/lib/mysql socket=/var/lib/mysql/mysql.sock character_set_server=utf8 collation-server=utf8_general_ci symbolic-links=0 log-error=/var/log/mysqld.log pid-file=/var/run/mysqld/mysqld.pid #set master-master env log_bin=master-bin log_bin_index=master-bin.index server-id=4 expire-logs-days=7 binlog_ignore_db=mysql binlog_ignore_db=information_schema binlog_ignore_db=performation_schema binlog_ignore_db=sys relay-log = slave-relay-bin relay-log-index = slave-relay-bin.index

    查看master状态并把自己当作从服务器指向对方为主服务器

    #all-nodes #重启mysqld systemctl restart mysqld #all-nodes 查看master状态 show master status; #master1-node #更改主服务器 change master to master_host='192.168.2.22', master_port=3306, master_user='replication', master_password='Replication@1', master_log_file='master-bin.000001', master_log_pos=154; #master2-node #更改服务器 change master to master_host='192.168.2.21', master_port=3306, master_user='replication', master_password='Replication@1', master_log_file='master-bin.000001', master_log_pos=154;

    启动从服务器

    #all-nodes start slave; show slave status\G

    测试

    master1服务器创建名为heetok1的数据库,里面表为heetok1,然后插入姓名heetok1,年龄21

    master2服务器查看数据库内容并且插入姓名heetok2,年龄22

    master1服务器查看两者同步

    综上所述,两个服务器已经互为主从,实现数据库主主互备的搭建。

    如有不妥,敬请指正~

    Processed: 0.009, SQL: 9