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生效!
相关推荐
数厘5 分钟前
2.3MySQL 表结构设计:提升 SQL 查询性能的关键
android·sql·mysql
亚马逊云开发者16 分钟前
Amazon Aurora PostgreSQL 快速配置实战:两次点击秒级创建无服务器数据库,告别 VPC 子网安全组配置噩梦
数据库·postgresql·serverless
晴天sir19 分钟前
Redis 在业务中的几种典型用法
java·数据库·redis
小羽网安19 分钟前
Linux 服务器如何进行安全加固?
linux·服务器·安全
jnrjian25 分钟前
B树index 的维护 Oracle
数据库·oracle
倔强的胖蚂蚁26 分钟前
AI 人工智能配置管理 Nginx
运维·nginx·云原生
上海云盾安全满满31 分钟前
服务器如果做好日常维护,有什么作用
运维·服务器
正在走向自律35 分钟前
企业级数据库存储运维实战:表空间自动创建与存储架构深度优化
运维·数据库·架构·表空间
jnrjian36 分钟前
Oracle 并发 锁
数据库
念风42 分钟前
[Linux学习笔记]Uboot-DM的分析过程
linux