MySQL主从配置魔法书:从小白到数据库大师的奇幻冒险之路!

2023年 12月 6日 39.3k 0

MySQL主从配置魔法书:从小白到数据库大师的奇幻冒险之路!

1.配置环境

1.1条件

这次的mysql为8.0.13版本,我们在三台测试服务器上部署,一台为主数据库,两台为从数据库:

Master:172.16.50.121

Slave: 172.16.50.122

Slave: 172.16.50.123

提示: 前提是每台服务器的mysql都已安装好,正式环境的三台服务器

1.2准备

在MySQL主从复制中,如果在从库连接到主库之前,主库上发生的数据更改(例如新建数据库或表、插入数据等)通常不会自动同步到从库。

2.主服务器配置

2.1首先需要配置my.cnf,打开mysql配置文件

vi /etc/my.cnf
显示如下

image.png

在[mysqld]下方添加如下配置,标记为主库,序号1(这里的server-id是唯一标记,要确保它的唯一性)
log-bin=mysql-bin 
server-id=1
完成后:

image.png

wq保存之后,重启mysql服务
service mysqld restart

2.2配置mysql

1.登录数据库,进入数据库命令行
mysql -u root -p
2.在mysql数据库中,建立用户同步数据库的账号和密码:
create user 'rem'@'%' identified with 'mysql_native_password' by '123456';
3.给rem用户权限,从库就可以通过此账户来连接主库:
GRANT replication slave ON *.* TO 'rem'@'%';
GRANT ALL privileges ON *.* TO 'rem'@'%'; flush privileges;
4.查看mysql主服务器日志:
SHOW MASTER STATUS;
会显示如下信息:

image.png

记录下查出来的File和Position的值,一会儿再从服务器上配置时使用,一般都不一样,这里的是:

File: binlog.000001
Position: 633210

最后要确认主服务器的3306端口是开放的

sudo firewall-cmd --zone=public --permanent --add-service=mysql 
sudo systemctl  restart firewalldshe
主数据库配置已经完成.

3.从服务器配置

3.1首先需要配置my.cnf,打开mysql的二进制配置文件

vi /etc/my.cnf

3.2在[mysqld]下方添加如下配置,标记为从库,序号2

log-bin=mysql-bin server-id=2
完成如下

image.png

wq保存之后,重启mysql服务
service mysqld restart

3.1登录数据库,进入数据库命令行,登录数据库

mysql -u root -p

3.2在从服务器设置主服务器信息,实现主从配置

change master to master_host='172.16.50.121',
master_user='rem',
master_password='123456',
master_log_file='binlog.000001' ,master_log_pos=633210;
说明:
  • MASTER_HOST='172.16.50.121' 主数据库的ip
  • MASTER_USER='rem', 创建的主库用户
  • MASTER_PASSWORD='123456', repl用户的密码
  • MASTER_LOG_FILE='binlog.000001', 主服务器上的File(记录)
  • MASTER_LOG_POS=633210; 刚刚保存的position

3.3开启从数据库SQL

start slave;

3.4查看连接状态

show slave statusG

image.png

发现这两个状态是否为Yes,如果是就配置成功了,其他状态No,connecting均代表有错误,需要进行调整,可能是下列的一些原因,可自行去排查

  • 网络不通 
  • 连接信息不对,包括端口 
  • 第二个从库跟第一个从库是一样的
    最后配置完成之后,添加数据更改数据之后,验证数据是否同步成功
    注意:在MySQL主从复制中,如果在从库连接到主库之前,主库上发生的数据更改(例如新建数据库或表、插入数据等)通常不会自动同步到从库。主从复制是一种基于二进制日志(binary log)的机制,只有连接建立后,从库才能获取并应用主库上的二进制日志。当你在从库上执行CHANGE MASTER TO和START SLAVE命令时,从库会连接到主库,并开始从主库的二进制日志中获取数据,然后同步到从库。如果在连接建立前有数据更改,从库是不会获取这些更改的。如果你希望确保从库与主库保持一致,可以在连接建立前手动导入主库上的数据到从库,或者使用其他手段确保数据一致性。一般而言,主从复制的目的是实时或准实时地将主库上的更改同步到从库,因此建议在设置主从复制时确保从库是空的或与主库一致的状态。

    相关文章

    Oracle如何使用授予和撤销权限的语法和示例
    Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
    下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
    社区版oceanbase安装
    Oracle 导出CSV工具-sqluldr2
    ETL数据集成丨快速将MySQL数据迁移至Doris数据库

    发布评论