|
/ |
主服务器 |
从服务器 |
|
Ip |
192.168.31,79 |
192.168.31.188 |
|
hostname |
mysql |
mysql2 |
|
mysql-version |
5.7.23 |
5.7.23 |
|
server-id |
0ac92118-59f9-11ea-8806-080027c1c1ff |
2516faba-65f4-11ea-82b6-080027b0e953 |
1.主库修改参数文件
[root@mysql soft]# vi /etc/my.cnf添加内容如下:
server-id=79 # 设置主服务器的ID(不能和别的服务器重复,随意)
innodb_flush_log_at_trx_commit=2 # 可以配置的值:0/1/2; 0、效率最高,最不安全;1、最安全,但是效率最低;2、安全和效率平衡的取舍,在服务器系统挂掉的情况下会丢失数据;
sync_binlog=1 # ,值可设置 1、500、1000;可自己根据测试性能配置
log-bin=mysql-bin #binlog 日志文件名
binlog-ignore-db=mysql # 表示不同步mysql库
binlog-ignore-db=information_schema
binlog-ignore-db=oggmysql
binlog-ignore-db=sys
binlog-ignore-db=performance_schema
binlog-do-db=TEST # 表示同步TEST库
2.主库创建同步账号
[root@mysql ~]# mysql -uroot -pmysql> create user 'sync'@'%' identified by 'Oracle123'mysql> grant FILe on *.* to 'sync'@'192.168.31.188' identified by 'Oracle123';#赋予FILE权限,允许从从库ip访问主库mysql> grant replication slave on *.* to 'sync'@'192.168.31.188' identified by 'Oracle123';#赋予主从同步权限mysql> flush privileges;
3.重启主库
[root@mysql ~]# service mysqld stop[root@mysql ~]# service mysqld start[root@mysql ~]# mysql -uroot -pmysql> show master status;
注:以上截图中的FILE,POSTTION在备库配置时需要使用到
4. 主库备份数据库
[root@mysql soft]# mysqldump --single-transaction -uroot -pOracle123 TEST > TEST_20200310.sql
5.从库恢复数据库
mysql> create database TEST;[root@mysql2 soft]# mysql -uroot -pOracle123 TEST < TEST_20200310.sql
6.从库参数修改
[root@mysql2 mysql]# vi /etc/my.cnf添加内容如下:
server-id=188
#log-bin=mysql-bin # 从库提高性能可以不开bin-log日志
replicate-ignore-db=mysql
binlog-ignore-db=information_schema
binlog-ignore-db=oggmysql
binlog-ignore-db=sys
binlog-ignore-db=performance_schema
binlog-do-db=TEST
innodb_flush_log_at_trx_commit=2 # 可以配置的值:0/1/2; 0、效率最高,最不安全;1、最安全,但是效率最低;2、安全和效率平衡的取舍,在服务器系统挂掉的情况下会丢失数据;
sync_binlog=1000 # 每进行n次事务提交之后,MySQL将binlog_cache中的数据强制写入磁盘。
slave_parallel_workers=4 # 根据实际情况决定开启多少个线程用于主从复制
slave_parallel_type=logical_clock # 基于组提交的并行复制方式
master_info_repository=TABLE
relay_log_info_repository=TABLE
relay_log_recovery=ON
7. 从库重启
[root@mysql2 data]# service mysql stop[root@mysql2 data]# service mysql start
8.从库配置
mysql> stop slave;mysql> change master to master_host='192.168.31.79', master_user='sync',master_password='Oracle123', master_log_file='mysql-bin.00001' ,master_log_pos=154;mysql> start slave;mysql> show slave status \G;

9.验证
1)主库插入数据mysql> insert into TEST values (7,'liuqi');2)备库查询mysql> select * from TEST;
