Mysql主从同步

发布于:2025-09-05 ⋅ 阅读:(15) ⋅ 点赞:(0)

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重启数据库

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

1.1.3查看数据库的编号

[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建立同步账号

[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锁表只读

#为后面备份准备,注意生产环境要提前申请停机时间;
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查看主库状态

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

1.1.7备份主数据库中数据

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

1.1.8解锁

mysql> unlock tables;

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

[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值

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

2.1.2重启数据库

[root@mysql-master172 ~]# /etc/init.d/mysqld restart

2.1.2还原从主库备份数据

[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设定从库向主库同步

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启动从库同步开关

mysql> start replica;

2.1.5检查状态

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

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

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

主库

mysql> create database haha;
Query OK, 1 row affected (0.01 sec)

从库

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在主配置文件中添加配置

binlog_ignore_db="information_schema"
binlog_ignore_db="mysql"
binlog_ignore_db="test"

4.1.2重启数据库

[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

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

4.3从库只读

read-only
innodb_read_only = ON或1
注:当用户权限中没有SUPER权限(ALL权限是包括SUPER的)时,从库的read-only生效!


网站公告

今日签到

点亮在社区的每一天
去签到