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

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

针对线上情况,需要保证三个数据库在连接之前是一样,包括数据库跟表,这里需要把线上的两个数据库:nsjz-cloud,nacos-prod导入到两个从库,保证在连接之前,线上的库表数据是一致的

2.主服务器配置

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

shell 复制代码
vi /etc/my.cnf
显示如下
在[mysqld]下方添加如下配置,标记为主库,序号1(这里的server-id是唯一标记,要确保它的唯一性)
shell 复制代码
log-bin=mysql-bin 
server-id=1
完成后:
wq保存之后,重启mysql服务
shell 复制代码
service mysqld restart

2.2配置mysql

1.登录数据库,进入数据库命令行
shell 复制代码
mysql -u root -p
2.在mysql数据库中,建立用户同步数据库的账号和密码:
sql 复制代码
create user 'rem'@'%' identified with 'mysql_native_password' by '123456';
3.给rem用户权限,从库就可以通过此账户来连接主库:
sql 复制代码
GRANT replication slave ON *.* TO 'rem'@'%';
GRANT ALL privileges ON *.* TO 'rem'@'%'; flush privileges;
4.查看mysql主服务器日志:
sql 复制代码
SHOW MASTER STATUS;
会显示如下信息:
记录下查出来的File和Position的值,一会儿再从服务器上配置时使用,一般都不一样,这里的是:

File: binlog.000001

Position: 633210

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

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

3.从服务器配置

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

shell 复制代码
vi /etc/my.cnf

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

shell 复制代码
log-bin=mysql-bin server-id=2
完成如下
wq保存之后,重启mysql服务
sql 复制代码
service mysqld restart

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

shell 复制代码
mysql -u root -p

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

sql 复制代码
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

sql 复制代码
start slave;

3.4查看连接状态

sql 复制代码
show slave status\G

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

  1. 网络不通
  2. 连接信息不对,包括端口
第二个从库跟第一个从库是一样的
最后配置完成之后,添加数据更改数据之后,验证数据是否同步成功
注意:在MySQL主从复制中,如果在从库连接到主库之前,主库上发生的数据更改(例如新建数据库或表、插入数据等)通常不会自动同步到从库。主从复制是一种基于二进制日志(binary log)的机制,只有连接建立后,从库才能获取并应用主库上的二进制日志。当你在从库上执行CHANGE MASTER TO和START SLAVE命令时,从库会连接到主库,并开始从主库的二进制日志中获取数据,然后同步到从库。如果在连接建立前有数据更改,从库是不会获取这些更改的。如果你希望确保从库与主库保持一致,可以在连接建立前手动导入主库上的数据到从库,或者使用其他手段确保数据一致性。一般而言,主从复制的目的是实时或准实时地将主库上的更改同步到从库,因此建议在设置主从复制时确保从库是空的或与主库一致的状态。
相关推荐
内核程序员kevin3 小时前
在Linux环境下使用Docker打包和发布.NET程序并配合MySQL部署
linux·mysql·docker·.net
CodingBrother4 小时前
MySQL 中的 `IN`、`EXISTS` 区别与性能分析
数据库·mysql
kayotin4 小时前
Wordpress博客配置2024
linux·mysql·docker
甄臻9244 小时前
Windows下mysql数据库备份策略
数据库·mysql
杀神lwz4 小时前
Java 正则表达式
java·mysql·正则表达式
山南2375 小时前
MySql-8.0.40安装详细教程
mysql
十言_6 小时前
MySQL远端访问
数据库·mysql
在下方方8 小时前
【快捷入门笔记】mysql基本操作大全-SQL表
笔记·sql·mysql
计算机学姐8 小时前
基于Python的药房管理系统
开发语言·vue.js·后端·python·mysql·pycharm·django
eternal__day8 小时前
MYSQL索引
数据库·mysql