MYSQL的架构中主从异步复制是怎么进行的

这篇文章将为大家详细讲解有关MYSQL的架构中主从异步复制是怎么进行的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

/

服务器

从服务器

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 -p

mysql> 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 -p

mysql> show master status;

MYSQL的架构中主从异步复制是怎么进行的

注:以上截图中的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;

MYSQL的架构中主从异步复制是怎么进行的

9.验证

1)主库插入数据

mysql> insert into TEST values (7,'liuqi');

2)备库查询

mysql> select * from TEST;

关于MYSQL的架构中主从异步复制是怎么进行的就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。