MySQL8 双主(主主)架构部署实战
创始人
2025-05-30 02:50:25
0

前言

大家好,我是 沐风晓月 本文收录于《数据库入门到精通系列》专栏, 更多内容可以关注我的csdn博客。

本文主要讲解MySQL主主架构实战,在开始之前需要根据下面的提示来配置环境:

  • Linux基础命令不熟参考: 《linux基本功-基础命令实战》专栏
  • MySQL8没有安装参考:《提高MySQL数据可靠性的必备技能:基于MySQL8实现主从同步》

本次实验需要提前配置好两台安装好MySQL8的服务器

文章目录

  • 前言
  • 一. 实验环境
  • 二. 实验配置
    • 2.1 数据库配置文件设置
      • 2.1.1 对数据库master1进行配置:
      • 2.1.2 修改master2 的配置文件
    • 2.2 相互设置主从架构
      • 2.2.1 对MySQ1配置主从
      • 2.2.2 对MySQL2配置主从
  • 总结

在这里插入图片描述

一. 实验环境

架构版本IPhostname
master1CentOS7.6192.168.1.41master41
master2CentOS7.6192.168.1.42master42

架构图如下:
在这里插入图片描述

数据库密码: Root!2#admin

二. 实验配置

2.1 数据库配置文件设置

要实现主主复制,就是在主从复制的基础上配置相互为主从。 这里很容易需要对两台服务器反复配置,很容易搞乱。

2.1.1 对数据库master1进行配置:

vim /etc/my.cnf[mysqld]server-id = 1                                                
log-bin=mysql-bind                                         
auto_increment_increment=2
auto_increment_offset=1
replicate-do-db=test_db

对上文代码进行注释:

  • server-id = 1 #任意自然n,只需要保证两台mysql主机不重复就可以

  • log-bin=mysql-bin #开启二进制日志

  • auto_increment_increment=2 #步进值auto_imcrement 。一般有n台主mysql就填n

  • auto_increment_offset=1 #起始值,一般填写第n台主机mysql.此时为第一台主 mysql

  • #binlog-ignore=mysql #忽略mysql库,可以不填写

  • #binlog-ignore=infomation_schema #忽略information_schema库,一般不填写

  • replicate-do-db=test_db #指定同步的数据库,不填写则默认所有的数据库

配置完成后,重启数据库

2.1.2 修改master2 的配置文件

配置文件[mysqld]模块下添加以下内容:

vim /etc/my.cnfserver-id = 2 
log-bin=mysql-bind
auto_increment_increment=2
auto_increment_offset=2
replicate-do-db=test_db

2.2 相互设置主从架构

2.2.1 对MySQ1配置主从

对MySQL1配置主从,在这里就是对192.168.1.41这台服务器设置MySQL主从,master1做为主库,master2作为从库。

  1. 把MySQL1这台数据设置为主库
  • 登录数据库:
root@mufeng41 ~]# mysql -uroot -p'Root!2#admin'
  • 创建复制哟ing胡
    这里设置的用户名是:mufeng41,密码 mysqlMufeng@passw0rd
create user 'mufeng41'@'%' identified with mysql_native_password by 'mysqlMufeng@passw0rd';      
#创建用户 mysql8.0中密码需要填写mysql_native_password
grant replication slave on *.* to 'mufeng41'@'%';                         
#分配权限
flush privileges;    
#刷新权限
  • 查看权限是否分配正确
mysql> show grants for 'mufeng41'@'%';
+--------------------------------------------------+
| Grants for mufeng41@%                            |
+--------------------------------------------------+
| GRANT REPLICATION SLAVE ON *.* TO `mufeng41`@`%` |
+--------------------------------------------------+
1 row in set (0.00 sec)
  • 查看master1的状态
mysql> show master status;
+---------------+----------+--------------+------------------+-------------------+
| File          | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+---------------+----------+--------------+------------------+-------------------+
| binlog.000001 |     1125 |              |                  |                   |
+---------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)mysql> 

2. 设置MySQL2为从库

  • 登陆master2数据库,执行同步语句
[root@mufeng42 ~]# mysql -uroot -p'Root!2#admin'
  • 在master2上执行同步语句
mysql> change master to master_host='192.168.1.41',-> master_user='mufeng41',-> master_password='mysqlMufeng@passw0rd',-> master_log_file='mysql-bin.000001',-> master_log_pos=1125;
Query OK, 0 rows affected, 8 warnings (0.01 sec)为方便下次使用这个SQL语句方便,这里改成一条语句,不分段的(切记不需要执行两遍):change master to master_host='192.168.1.41',master_user='mufeng41',master_password='mysqlMufeng@passw0rd',master_log_file='mysql-bin.000001',master_log_pos=1125;
  • 启动slave同步
    这一步骤是在MySQL2中启动,因为目前MySQL2是从库
mysql> start slave;
Query OK, 0 rows affected, 1 warning (0.01 sec)

3.测试主从是否成功

先在主数据库插入数据,然后从从库进行查询:

  • 主库操作如下:
mysql> create database test_db;
Query OK, 1 row affected (0.01 sec)
  • 从库查看结果:
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
| test_db            |
+--------------------+
5 rows in set (0.01 sec)mysql> 

至此已经配置成功master1做为主库,MySQL2做为从库的情况,如果你在配置这一步的时候,遇到问题,比如主从不同步的情况,可以参考文章:《成功解决主从同步异常之Slave_IO_Running显示为No的问题》

2.2.2 对MySQL2配置主从

此时 设置的主库为master2,从库为master1

1. 配置master2为主master服务器

  • 先对master2上进行授权
create user 'mufeng42'@'%' identified with mysql_native_password by 'mysqlMufeng@passw0rd';      
#创建用户 mysql.80中密码需要填写mysql_native_password
grant replication slave on *.* to 'mufeng42'@'%';                         
#分配权限
flush privileges;    
  • 查看master2作为master服务器的状态:
mysql> show master status;
+-------------------+----------+--------------+------------------+-------------------+
| File              | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+-------------------+----------+--------------+------------------+-------------------+
| mysql-bind.000001 |     1051 |              |                  |                   |
+-------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

2. 配置master1为从服务器

  • 在master1 上执行同步语句,作为从服务器:
mysql> change master to master_host='192.168.1.42', master_user='mufeng42', master_password='mysqlMufeng@passw0rd', master_log_file='mysql-bin.000001', master_log_pos=1051;
Query OK, 0 rows affected, 8 warnings (0.01 sec)
  • 开启slave同步,检查slave状态
mysql> start slave;
mysql> stop slave;
Query OK, 0 rows affected, 1 warning (0.01 sec)有时候显示不同步可以直接设置reset slavemysql> reset slave;
Query OK, 0 rows affected, 1 warning (0.01 sec)mysql> start slave;
Query OK, 0 rows affected, 1 warning (0.01 sec)
  • 查看主从是否配置成功
mysql> show slave status \G


3. 插入数据进行主从测试

  • 然后在master2上创建数据在master1上进行查看
    此时的master2是主服务器
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
| test_db            |
+--------------------+
5 rows in set (0.00 sec)mysql> use test_db
Database changed
mysql> create table test_db(id int,name varchar(20));
Query OK, 0 rows affected (0.01 sec)
  • 在master1进行查看是否同步
mysql> use test_db;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -ADatabase changed
mysql> show tables;
+-------------------+
| Tables_in_test_db |
+-------------------+
| test_db           |
+-------------------+
1 row in set (0.01 sec)

可以看到,数据已经同步过来了,至此MySQL主主架构就配置完成了。

总结

以上就是主主架构配置的全部内容了,如果对你有用,欢迎点赞收藏哦。

💕 好啦,这就是今天要分享给大家的全部内容了,我们下期再见!
💕 本文由沐风晓月原创,首发于CSDN博客, 博客主页:mufeng.blog.csdn.net
💕 学习如逆水行舟,不进则退,一起努力加油哦!
💕 喜欢的话记得点赞收藏哈

相关内容

热门资讯

银行职工因贪污罪获刑后留任,在... 新京报记者 刘锦涵 制作 礼牧周 ▲新京报我们视频出品(ID:wevideo) 近日,农发行福建福鼎...
黄金创40年来最大单日跌幅!金... (来源:劳动报) 转自:劳动报 1月31日,国际金银价格同步大跌,创40余年来最大跌幅。国内金饰价...
“一人公司”近来何以兴起? 2026年开年,“一人公司”发展备受关注。这种新型创业模式正在上海、北京、江苏等地悄然兴起,凭借低成...
寒武纪预计 2025 年净利润... 消息,AI 芯片企业寒武纪今日发布 2025 年年度业绩预告: 经财务部门初步测算,公司预计 2...
和讯投顾徐剑波:ETF买入法! 这轮牛市是机构主导的ETF牛市,选对ETF往往比选股更加赚钱。那么如何投资ETF?今天教给大家一个非...
君乐宝上市申请已递交,国内乳品... 2026年 1月19日,中国领先的综合乳制品企业君乐宝乳业集团股份有限公司正式向香港联交所递交主板上...
大涨!马斯克,突传大消息!重磅... SpaceX的“赚钱能力”曝光。 据最新消息,世界首富埃隆·马斯克旗下的商业航天公司SpaceX去年...
原创 顶... 2025年微博之夜定档于2026年2月5日北京线上直播,这场已经走过二十多年风雨的互联网年度盛典,因...
体检查出肺结节?3个日常行为正... 太原龙城中医医院科普:如今越来越多人在体检中发现肺结节,看到报告上的“阴影”便忧心忡忡。其实研究表明...
记者观察丨美联储下任主席提名揭... 在经过长达一年反复挑选后,美国总统唐纳德·特朗普终于做出决定,提名凯文·沃什为下一任美联储主席,接替...
首饰金,一夜大跌上百元!金价暴... 【导读】多家首饰品牌金价出现大幅下跌 中国基金报记者 忆山 随着国际金价急速下跌,国内首饰金价也迎来...
原创 一... 一个亲自参观过我国稀土提炼工厂的日本人在社交平台发文,竟然毫不客气地指出,无论是日本还是美国,都几乎...
环球网财经系列专访 1月27日至28日,全国贸促工作会议暨中国贸促会第六届全国委员会第六次会议在京召开。 会议指出,“...
默茨警告:“大国世界”要来了,... 【文/观察者网 熊超然】当地时间1月29日,德国总理默茨在德国联邦议院发表其任内的第二次施政声明。在...
路透解析“马斯克集团”:Spa... SpaceX 凤凰网科技讯 北京时间1月31日,据路透社报道,长期以来,埃隆·马斯克(Elon Mu...
启动“二改” 永辉在京完成21... 北京商报讯(记者 赵述评 实习记者 毛思怡)1月31日,永辉超市北京龙湖长楹天街店经一个多月闭店调改...
《宜宾散装白酒连锁经营规范》团... 近日,由宜宾市酒类协会牵头归口、宜宾安宁酒厂主导起草,四川谊宾酒业、宜宾学院、劲牌南溪酒业等多家本地...
印度牙医博士打造全印首款人形机... 2026 年 1 月 23 日,印度浦那的 Muks Robotics 正式宣布,自主研发的社交人形...
金银价创新高,引发全球“贵金属... 【环球时报记者 倪浩 环球时报特约记者 甄翔】连日来,国际市场金银价格持续大涨。1月29日当天,亚太...
财经观察丨“爱你老己”背后的消... 新华网北京1月31日电岁末年初,一句“爱你老己,明天见”席卷社交网络,成为年轻人自我关怀的新表达。热...