MySQL数据库一主一从集群配置

环境
  • 环境三部曲

    • 1.全新服务器-互相通信
    • 2.全新安装mysql8.0-分别安装
    • 3.配置域名解析
      这里来讲一主一从的第二种连接方式,第一种的话可以参考下面连接:
      第一种方式
一主一从(M-S)(2)
需求
  • 实验2与上一个实验需求基本相同。

    master1 作为主mysql

    master2 作为从mysql。

  • 不同之处,使用了 "

    gtid_mode=ON

    enforce_gtid_consistency=1"

    该属性自动记录position位置。不需要手动指定了。

注释:

复制代码
gtid_mode=ON 意味着你的服务器将启用 GTID
enforce_gtid_consistency=1
enforce_gtid_consistency 是强制统一全局数据标识符,1是开启
环境
  • 因与实验1功能相同

  • 请重置master2数据库

    powershell 复制代码
    # systemctl stop mysqld
    # rm -rf /var/lib/mysql/*
    # systemctl start mysqld
    # grep password /var/log/mysqld.log
    # mysqladmin -uroot -p'老的密码' password 'Lixinyi@123'
    
    
    # mysql -uroot -p'Lixinyi@123'

master1

  • 1 启动二进制日志,服务器ID,GTID

    复制代码
     vim /etc/my.cnf
     
     log_bin 
     server-id=1 
     gtid_mode=ON 
     enforce_gtid_consistency=1
     
     
     systemctl restart mysqld
  • 2 授权复制用户rep(略)

bash 复制代码
grant replication slave,replication client on *.* to 'rep'@'192.168.145.%' identified by 'Lixinyi@123';

flush privileges;
  • 3 备份数据

    powershell 复制代码
    # mysqldump -p'Lixinyi@123' --all-databases --single-transaction --master-data=2 --flush-logs > `date +%F-%H-%M`-mysql-all.sql
    
    master-data=2设置为2,已经不需要这个标记了。
    powershell 复制代码
    # scp 2024-07-15-03-38-mysql-all.sql     master2:/tmp
  • 4 模拟数据变化

    sql 复制代码
    mysql>insert into master1db.master1tab values (6666666666);
    mysql> select * from master1db.master1tab;
(master2)
  • 1 测试rep用户是否可用

    • master2

      复制代码
      mysql -h master1 -urep -p'Lixinyi@123'
      • 预防账户问题。
      • 注意防火墙应该关闭
  • 2 启动二进制日志,服务器ID,GTID

    复制代码
     vim /etc/my.cnf 
     log_bin 
     server-id=2 
     gtid_mode=ON 
     enforce_gtid_consistency=1
     
     
     systemctl restart mysqld
    • 测试配置是否有问题,如果启动失败。请检查配置。
  • 3 手动恢复master1数据

    powershell 复制代码
     mysql>set sql_log_bin=0;  //临时关闭二进制日志,退出数据库就又启动了
     mysql>source /tmp/2024-07-15-03-38-mysql-all.sql
     mysql>select * from master1db.master1tab;
    • 该实验的关键效果即将出现。
  • 4 设置主服务器

    复制代码
    mysql> change master to
    master_host='192.168.145.141',
    master_user='rep',
    master_password='Lixinyi@123',
    master_auto_position=1;
    • 注意,和前一个实验比少了两行

      复制代码
      mysql> change master to master_host='192.168.145.141', master_user='rep', master_password='Lixinyi@123', master_log_file='localhost-bin.000002', master_log_pos=154;
    复制代码
      start slave;
bash 复制代码
show slave status\G;

5 返回主服务器(master1)更新数据,在从服务器(master2)观察是否同步。

相关推荐
xiaoshuaishuai87 分钟前
C# Submodule 避坑指南
服务器·数据库·windows·c#
2501_9142459314 分钟前
C#怎么使用属性Property C#自动属性和完整属性的区别get set怎么用【基础】
jvm·数据库·python
绩隐金18 分钟前
SQL 与查询优化(PostgreSQL 篇)· 第五期
数据库
安当加密26 分钟前
SQL Server 数据库安全新范式:TDE 透明加密+ DBG数据库安全网关 双重装甲
数据库·oracle
java干货42 分钟前
如果光缆被挖断导致 Redis 出现两个 Master,怎么防止数据丢失?
数据库·redis·缓存
2401_837163891 小时前
CSS如何实现网页打印样式优化_利用@media print重写布局
jvm·数据库·python
Irene19911 小时前
Oracle 21c XE 安装后默认不包含HR等示例表,CO 模式、SCOTT 模式安装过程记录
数据库·oracle
李白客1 小时前
能源系统数据库:面向智能电网与新能源场景的五大核心能力
数据库·能源
观北海1 小时前
机器人调度系统死锁卡死全复盘及解决方案
数据库·机器人
DolphinDB智臾科技1 小时前
高频行情低频化因子库:让 Tick 级数据为中低频策略所用
数据库·金融