Mysql主从同步

1.主库配置

1.1主库(mysql-master171): ip(192.168.75.171) port(3306)

1.1.1设置server-id值并开启binlog参数

复制代码
[root@mysql-master171 ~]# vim /etc/my.cnf
[mysqld]
datadir=/data/mysql   
socket=/data/mysql/mysql.sock  
server_id=171
log-bin=binlog

1.1.2重启数据库

bash 复制代码
[root@mysql-master171 ~]# /etc/init.d/mysqld restart
Shutting down MySQL. SUCCESS!
Starting MySQL. SUCCESS!

1.1.3查看数据库的编号

bash 复制代码
[root@mysql-master171 ~]# mysql -uroot -p123 -e 'select @@server_id;'
mysql: [Warning] Using a password on the command line interface can be insecure.
+-------------+
| @@server_id |
+-------------+
|         171 |
+-------------+

1.1.4建立同步账号

bash 复制代码
[root@mysql-master171~]# mysql -uroot -p123
mysql> create user 'rep'@'%' identified  by 'rep123';
mysql> grant  replication slave on *.* to 'rep'@'%';
#查看权限
mysql>  show grants for 'rep'@'%';
+---------------------------------------------+
| Grants for rep@%                            |
+---------------------------------------------+
| GRANT REPLICATION SLAVE ON *.* TO `rep`@`%` |
+---------------------------------------------+

1.1.5锁表只读

bash 复制代码
#为后面备份准备,注意生产环境要提前申请停机时间;
mysql> flush tables with read lock;
#提示:如果超过设置时间不操作会自动解锁。
mysql> show variables like '%timeout%';
#测试锁表后是否可以创建数据库:
mysql> create database test;
ERROR 1223 (HY000): Can't execute the query because you have a conflicting read lock

1.1.6查看主库状态

bash 复制代码
#查看主库状态,即当前日志文件名和二进制日志偏移量
mysql> show master status;
+---------------+----------+--------------+------------------+-------------------+
| File          | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+---------------+----------+--------------+------------------+-------------------+
| binlog.000006 |     324 |              |                  |                   |
+---------------+----------+--------------+------------------+-------------------+
#注意:如果想要重置主库,可以使用reset master;生产环境慎用

1.1.7备份主数据库中数据

bash 复制代码
[root@mysql-master171 ~]# mysqldump -uroot -p123  --all-databases> /backup/mysql_bak.2025-09-03.sql.gz 

1.1.8解锁

bash 复制代码
mysql> unlock tables;

1.1.9主库备份数据上传到从库

bash 复制代码
[root@mysql-master171 ~]# scp  /backup/mysql_bak.2025-09-03.sql.gz 192.168.75.172:/backup

2.从库配置

2.1从库(mysql-master172):ip(192.168.75.172)port(3306)

2.1.1设置server-id值

bash 复制代码
[root@mysql-master172 ~]# vim /etc/my.cnf
[mysqld]
datadir=/data/mysql
socket=/data/mysql/mysql.sock
server_id=172

2.1.2重启数据库

bash 复制代码
[root@mysql-master172 ~]# /etc/init.d/mysqld restart

2.1.2还原从主库备份数据

bash 复制代码
[root@mysql-mster172 ~]# cd /backup/
[root@mysql-mster172 ~]# gzip  -d mysql_bak.2025-09-03.sql.gz
[root@mysql-mster172 ~]# mysql -uroot -p < mysql_bak.2025-09-03.sql.gz
#检查还原:
[root@mysql-mster172 ~]# mysql -uroot -p -e 'show databases;'

2.1.3设定从库向主库同步

bash 复制代码
mysql> CHANGE REPLICATION SOURCE TO
SOURCE_HOST='192.168.75.171',
SOURCE_USER='rep',
SOURCE_PASSWORD='rep123',
SOURCE_LOG_FILE='binlog.000006',
SOURCE_LOG_POS=324,
SOURCE_SSL=1; 

2.1.4启动从库同步开关

bash 复制代码
mysql> start replica;

2.1.5检查状态

bash 复制代码
mysql> show replica status\G
Slave_IO_Running: Yes    #IO线程是否打开
Slave_SQL_Running: Yes   #SQL线程是否打开

3.MySQL主从复制的状况监测

3.1主库创建一个数据库,从库查看

主库

bash 复制代码
mysql> create database haha;
Query OK, 1 row affected (0.01 sec)

从库

bash 复制代码
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| haha               |
| information_schema |
| jeams              |
| mysql              |
| performance_schema |
| relay              |
| sys                |
+--------------------+
7 rows in set (0.00 sec)

4.生产环境其他常用设置

4.1配置不记录information_schema mysql test 等数据库的操作(增,删,改)的二进制日志文件

4.1.1在主配置文件中添加配置

bash 复制代码
binlog_ignore_db="information_schema"
binlog_ignore_db="mysql"
binlog_ignore_db="test"

4.1.2重启数据库

bash 复制代码
[root@mysql-master171 ~]# /etc/init.d/mysqld  restart
[root@mysql-master171 ~]# mysql -uroot -p -e 'show master status\G'
Enter password:
*************************** 1. row ***************************
             File: binlog.000004
         Position: 157
     Binlog_Do_DB:
 Binlog_Ignore_DB: information_schema,mysql,test
Executed_Gtid_Set:

4.2从库开始备份binlog

bash 复制代码
log-slave-updates  #当从库为其它从库的主库时必须要添加该参数
log_bin = mysql-bin  #设置二进制日志文件的文件前缀为mysql-bin
expire_logs_days = 7  #设置二进制日志文件的保留时间
应用场景:级联复制或从库做数据备份

4.3从库只读

bash 复制代码
read-only
innodb_read_only = ON或1
注:当用户权限中没有SUPER权限(ALL权限是包括SUPER的)时,从库的read-only生效!
相关推荐
十日十行7 小时前
Linux和window共享文件夹
linux
李广坤10 小时前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
木心月转码ing14 小时前
WSL+Cpp开发环境配置
linux
Turnip12021 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区1 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
蝎子莱莱爱打怪2 天前
Centos7中一键安装K8s集群以及Rancher安装记录
运维·后端·kubernetes
崔小汤呀2 天前
最全的docker安装笔记,包含CentOS和Ubuntu
linux·后端
随逸1772 天前
《从零搭建NestJS项目》
数据库·typescript
何中应2 天前
vi编辑器使用
linux·后端·操作系统
何中应2 天前
Linux进程无法被kill
linux·后端·操作系统