MySQL双主搭建-5.7.35

news/2025/2/27 7:33:53/

文章目录

    • 上传并安装MySQL 5.7.35
    • 双主复制的配置
      • 实例一:172.25.0.19:
      • 实例二:172.25.0.20:
    • 配置复制用户
      • 在实例 1 (172.25.0.19)上执行:
      • 在实例 2 (172.25.0.20)上执行:
    • 配置主从复制
      • 查看实例 2 节点状态:
      • 在实例 1 上执行:
      • 查看实例 1 节点状态:
      • 在实例 2 上执行:
    • 验证复制状态
    • 测试双主复制
      • 在 Server A 上操作:
      • 在 Server B 上操作:
      • 回到 Server A 上操作:

上传并安装MySQL 5.7.35

(172.25.0.19与172.25.0.20均部署安装并启动)

[root@QYWLAQ_VMC4234 ~]# hostnamectlStatic hostname: QYWLAQ_VMC4234Icon name: computer-vmChassis: vmMachine ID: cd3605d12efd430fb723eb507cf5ce3bBoot ID: 00f929e5510944efb40d53ef55d92a49Virtualization: kvmOperating System: CentOS Linux 7 (Core)CPE OS Name: cpe:/o:centos:centos:7Kernel: Linux 3.10.0-1160.el7.x86_64Architecture: x86-64[root@QYWLAQ_VMC4234 ~]# ll
-rw-r--r--  1 citc unicom  26658592 1225 17:02 mysql-community-client-5.7.35-1.el7.x86_64.rpm
-rw-r--r--  1 citc unicom    317800 1225 17:03 mysql-community-common-5.7.35-1.el7.x86_64.rpm
-rw-r--r--  1 citc unicom   2473348 1225 17:03 mysql-community-libs-5.7.35-1.el7.x86_64.rpm
-rw-r--r--  1 citc unicom   1263816 1226 14:35 mysql-community-libs-compat-5.7.35-1.el7.x86_64.rpm
-rw-r--r--  1 citc unicom 182213816 1225 17:05 mysql-community-server-5.7.35-1.el7.x86_64.rpm# 安装rpm包
[root@QYWLAQ_VMC4234 ~]# yum localinstall -y *.rpm# 启动并设置开启自启
[root@QYWLAQ_VMC4234 ~]# systemctl enable --now mysqld[root@QYWLAQ_VMC4234 citc]# systemctl status mysqldmysqld.service - MySQL ServerLoaded: loaded (/usr/lib/systemd/system/mysqld.service; enabled; vendor preset: disabled)Active: active (running) since 三 2025-02-26 12:24:03 CST; 4min 26s agoDocs: man:mysqld(8)http://dev.mysql.com/doc/refman/en/using-systemd.htmlProcess: 8441 ExecStart=/usr/sbin/mysqld --daemonize --pid-file=/var/run/mysqld/mysqld.pid $MYSQLD_OPTS (code=exited, status=0/SUCCESS)Process: 8374 ExecStartPre=/usr/bin/mysqld_pre_systemd (code=exited, status=0/SUCCESS)Main PID: 8444 (mysqld)Tasks: 27Memory: 289.2MCGroup: /system.slice/mysqld.service└─8444 /usr/sbin/mysqld --daemonize --pid-file=/var/run/mysqld/mysqld.pid226 12:23:57 QYWLAQ_VMC4234 systemd[1]: Starting MySQL Server...
226 12:24:03 QYWLAQ_VMC4234 systemd[1]: Started MySQL Server.# 获取初始密码
[root@QYWLAQ_VMC4234 citc]# sudo grep 'temporary password' /var/log/mysqld.log
2025-02-26T04:23:59.794639Z 1 [Note] A temporary password is generated for root@localhost: IlM3/)Ya6VMH# 登录
[root@QYWLAQ_VMC4234 citc]# mysql -u root -p'IlM3/)Ya6VMH'
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.7.35Copyright (c) 2000, 2021, Oracle and/or its affiliates.Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '8th3xY]:NA'; -- 修改root密码
Query OK, 0 rows affected (0.00 sec)mysql> FLUSH PRIVILEGES; -- 刷新权限以使修改立即生效
Query OK, 0 rows affected (0.01 sec)

双主复制的配置

实例一:172.25.0.19:

# 此配置文件中追加下述配置
[root@QYWLAQ_VMC4234 ~]# vi /etc/my.cnf[mysqld]
# 基本配置
server-id = 1                     # 每个实例的 server-id 必须唯一
log_bin = /var/log/mysql/mysql-bin.log  # 启用二进制日志
binlog_format = ROW               # 推荐使用 ROW 格式
expire_logs_days = 7              # 自动清理 7 天前的日志
max_binlog_size = 100M            # 每个二进制日志文件的最大大小# 双主复制配置
log_slave_updates = 1             # 从库记录二进制日志(必须启用)
auto_increment_increment = 2      # 自增步长
auto_increment_offset = 1         # 自增起始值(实例 1 为 1,实例 2 为 2)# 复制过滤(可选)
replicate-do-db = my_database     # 只复制指定的数据库
replicate-ignore-db = mysql       # 忽略系统库# 其他配置
bind-address = 0.0.0.0            # 允许远程连接

重启MySQL

[root@QYWLAQ_VMC4234 ~]# systemctl restart mysqld

实例二:172.25.0.20:

# 此配置文件中追加下述配置
[root@QYWLAQ_VMC1091 ~]# vi /etc/my.cnf[mysqld]
# 基本配置
server-id = 2                     # 每个实例的 server-id 必须唯一
log_bin = /var/log/mysql/mysql-bin.log  # 启用二进制日志
binlog_format = ROW               # 推荐使用 ROW 格式
expire_logs_days = 7              # 自动清理 7 天前的日志
max_binlog_size = 100M            # 每个二进制日志文件的最大大小# 双主复制配置
log_slave_updates = 1             # 从库记录二进制日志(必须启用)
auto_increment_increment = 2      # 自增步长
auto_increment_offset = 2         # 自增起始值(实例 1 为 1,实例 2 为 2)# 复制过滤(可选)
replicate-do-db = my_database     # 只复制指定的数据库
replicate-ignore-db = mysql       # 忽略系统库# 其他配置
bind-address = 0.0.0.0            # 允许远程连接

重启MySQL

[root@QYWLAQ_VMC1091 ~]# systemctl restart mysqld

配置复制用户

在每个 MySQL 实例上创建一个用于复制的用户。

在实例 1 (172.25.0.19)上执行:

mysql">mysql> CREATE USER 'replication'@'172.25.0.20' IDENTIFIED BY '@2X0wZY/rq';
Query OK, 0 rows affected (0.01 sec)mysql> GRANT REPLICATION SLAVE ON *.* TO 'replication'@'172.25.0.20';
Query OK, 0 rows affected (0.00 sec)mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.01 sec)

查询用户

mysql">mysql> SELECT User, Host FROM mysql.user;
+---------------+-------------+
| User          | Host        |
+---------------+-------------+
| replication   | 172.25.0.20 |
| mysql.session | localhost   |
| mysql.sys     | localhost   |
| root          | localhost   |
+---------------+-------------+
4 rows in set (0.00 sec)

在实例 2 (172.25.0.20)上执行:

mysql">mysql> CREATE USER 'replication'@'172.25.0.19' IDENTIFIED BY '@2X0wZY/rq';
Query OK, 0 rows affected (0.00 sec)mysql> GRANT REPLICATION SLAVE ON *.* TO 'replication'@'172.25.0.19';
Query OK, 0 rows affected (0.00 sec)mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.00 sec)

查询用户

mysql">mysql> SELECT User, Host FROM mysql.user;
+---------------+-------------+
| User          | Host        |
+---------------+-------------+
| replication   | 172.25.0.19 |
| mysql.session | localhost   |
| mysql.sys     | localhost   |
| root          | localhost   |
+---------------+-------------+
4 rows in set (0.00 sec)

配置主从复制

在每个实例上配置对方为主库。

查看实例 2 节点状态:

mysql">mysql> SHOW MASTER STATUS;
+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000002 |      964 |              |                  |                   |
+------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

在实例 1 上执行:

mysql">CHANGE MASTER TOMASTER_HOST='172.25.0.20',MASTER_USER='replication',MASTER_PASSWORD='@2X0wZY/rq',MASTER_LOG_FILE='mysql-bin.000002',     -- 替换为实例 2 的当前 binlog 文件MASTER_LOG_POS=1784;                     -- 替换为实例 2 的当前 binlog 位置
START SLAVE;

查看实例 1 节点状态:

mysql">mysql> SHOW MASTER STATUS;
+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000002 |      964 |              |                  |                   |
+------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

在实例 2 上执行:

mysql">CHANGE MASTER TOMASTER_HOST='172.25.0.19',MASTER_USER='replication',MASTER_PASSWORD='@2X0wZY/rq',MASTER_LOG_FILE='mysql-bin.000002',     -- 替换为实例 1 的当前 binlog 文件MASTER_LOG_POS=1784;                     -- 替换为实例 1 的当前 binlog 位置
START SLAVE;

验证复制状态

在每个实例上执行以下命令,检查复制状态:

mysql">SHOW SLAVE STATUS\G;

确保以下字段的值为 Yes

  • Slave_IO_Running
  • Slave_SQL_Running

测试双主复制

在 Server A 上操作:

创建测试数据库和表

CREATE DATABASE test_db;
USE test_db;
CREATE TABLE test_table (id INT AUTO_INCREMENT PRIMARY KEY,name VARCHAR(50)
) ENGINE=InnoDB;

插入数据

INSERT INTO test_table (name) VALUES ('Server A Data');

在 Server B 上操作:

检查数据是否同步

USE test_db;
SELECT * FROM test_table;

应该能看到 Server A Data

插入数据

INSERT INTO test_table (name) VALUES ('Server B Data');

回到 Server A 上操作:

检查数据是否同步

USE test_db;
SELECT * FROM test_table;

table (name) VALUES (‘Server A Data’);

### 在 Server B 上操作:**检查数据是否同步**:

USE test_db;
SELECT * FROM test_table;


应该能看到 `Server A Data`。**插入数据**:

INSERT INTO test_table (name) VALUES (‘Server B Data’);


### 回到 Server A 上操作:**检查数据是否同步**:

USE test_db;
SELECT * FROM test_table;


应该能看到 `Server B Data`。

http://www.ppmy.cn/news/1575207.html

相关文章

DDNS-GO 动态域名解析

什么是 DDNS DNS(域名系统) 是互联网的电话簿,将易于记忆的域名(如 www.example.com)转换为计算机可以理解的 IP 地址(如 192.0.2.1)。这使得用户无需记住复杂的数字地址即可访问网站。 DDNS&…

在单片机中,如果我的字符串里面有变量,怎么把字符串变ascii码

/********************************************* 函数名:Video_SwitchData(uint32_t data1, uint32_t data2) 功能:输入输出切换一对一发送给视频板函数;格式(sw,输入端口,输出端口) data1:输入通道,0x30-0x33 data2:…

MySQL保存超字段长度信息时如何正确截取

在Java中,为确保错误信息errMsg正确截取并适配MySQL的varchar(1024)字段(UTF-8编码),需考虑字符数限制及Unicode完整性。以下是实现方法: 解决方案 使用代码点(Code Point)截取,避…

第16届蓝桥杯模拟赛3 python组个人题解

第16届蓝桥杯模拟赛3 python组 思路和答案不保证正确 1.填空 如果一个数 p 是个质数,同时又是整数 a 的约数,则 p 称为 a 的一个质因数。 请问, 2024 的最大的质因数是多少? 因为是填空题,所以直接枚举2023~2 &am…

java23种设计模式-组合模式

组合模式(Composite Pattern)学习笔记 🌟 定义 组合模式属于结构型设计模式,用于将对象组合成树形结构以表示"部分-整体"层次结构。它使得用户对单个对象和组合对象的使用具有一致性。 🎯 适用场景 需要表…

从0-1搭建mac环境最新版

从0-1搭建mac环境 先查看自己的芯片信息 bash uname -mbash-3.2$ uname -m arm64这里是自己的型号安装brew xcode-select --install xcode-select -p /bin/zsh -c “$(curl -fsSL https://gitee.com/cunkai/HomebrewCN/raw/master/Homebrew.sh)” source /Users/lanren/.…

常见软件测试工具的解释

以下是一些常见软件测试工具的解释: 功能测试工具 Selenium:用于Web应用程序测试的开源工具,支持多种浏览器和编程语言,如Java、Python等。它通过操作浏览器来模拟用户行为,如点击按钮、输入文本、验证页面元素等&…

单片机总结【GPIO/TIM/IIC/SPI/UART】

一、GPIO 1、概念 通用输入输出口;开发者可以根据自己的需求将其配置为输入或输出模式,以实现与外部设备进行数据交互、控制外部设备等功能。简单来说,GPIO 就像是计算机或微控制器与外部世界沟通的 “桥梁”。 2、工作模式 工作模式性质特…