MySQL Replication主从复制—(实例)

2020年3月19日22:55:13
评论

主从复制原理

  • MySQL Replication是一个从Master复制到一台或多台Slave的异步复制过程。
  • Master和Slave之间实现整个复制过程主要由三个线程来完成,其中一个IO线程在Master端,两个线程(SQL线程和IO线程)在Slave端。
  • 通过Master服务器打开Binary Log(二进制日志文件)的功能,Slave端从Master端获取该日志信息,然后将二进制文件解析为SQL语句,并完全顺序地执行SQL语句所记录的各种操作。(Slave获取到的二进制文件同时也会写入到自身的Relay Log文件中)

Replication概念

  • MySQL Replication技术是一个日志复制过程,在复制过程中一台服务器充当主,一台或多台其他服务器充当从服务器;
  • 从服务器到主服务器拉取二进制日志文件,将日志文件解析成相应的SQL语句,然后在从服务器上重新执行一遍主服务器的操作,通过这种方式保证数据的一致性。

主从复制配置步骤:

  • 设置server-id(服务器标识,在一组主从中不能重复)
  • 开启二进制日志并指定二进制日志文件保存的路径
  • 记录bin-log文件和bin-log(position)位置
  • 若不停在Master时,加入全局锁,将需要同步的数据库备份到Slave节点上,解除全局锁
  • 创建用于同步复制的用户
  • 使用change master 在Slave和Master建立连接(Slave节点设置主服务器)
  • 启动Slave
  • 检查Slave的状态 

Step1:配置master和slave的/etc/my.cnf文件

1 2 3 4 5 6 7 8 9 10 11 12 13 ##Master    [mysqld] basedir= /usr/local/mysql datadir= /data/mysql/mysql port=3306 socket= /var/lib/mysql/mysql .sock    server- id =1                              #服务标识 log-bin= /data/mysql/binlog/mysql-bin    #binlog日志文件保存的路径 binlog-cache-size=10m                    #binlog日志缓存大小 sync -binlog=1                            #每隔N秒将缓存中的二进制日志记录写回硬盘 expire_logs_days=30                      #二进制日志文件过期时间(自动清理时间)

 

1 2 3 4 5 6 7 8 9 10 11 12 13 ##Slave    [mysqld] basedir= /usr/local/mysql datadir= /data/mysql/mysql port=3306 socket= /var/lib/mysql/mysql .sock    server_id=2 relay-log= /data/mysql/binlog/mysql-relay-bin replicate-wild- do -table=testdb1.%        #指定需要同步的数据库 replicate-wild- do -table=testdb2.%        #指定需要同步的数据库                                           #(与之对应的是replicate-wild-ignore-table)

Step2:手动同步数据库到slave

1、锁定Master的表的写操作(不要退出终端)

1 2 mysql> flush tables with  read  lock; Query OK, 0 rows affected (0.00 sec)


2、Master上备份数据库并传到Slave上

1 2 3 4 5 [[email protected] ~] # mysqldump -uroot -pRedHat testdb1 > /root/testdb1.sql [[email protected] ~] # tar zcf testdb1.tar.gz testdb1.sql    [[email protected] ~] # rsync -av /root/testdb1.tar.gz 192.168.1.211:/root/ [[email protected] ~] # scp /root/testdb1.tar.gz [email protected]:/tmp/

 

3、Slave上创建同步的数据库并导入数据文件

1 2 3 4 5 6 7 8 9 [[email protected] ~] # mysql -uroot -predhat -e 'create database testdb1' [[email protected] ~] # mysql -uroot -predhat testdb1 < testdb1.sql  mysql> show tables; +-------------------+ | Tables_in_testdb1 | +-------------------+ | tt1               | | tt2               | +-------------------+

 

Step3:Master创建同步的用户

 

1、Master解除锁定

1 mysql> unlock tables;

2、创建同步用户

1 2 mysql> grant replication slave on *.* to  'repl_user' @ '192.168.1.211'  identified by  'repl_passwd' ; mysql> flush privileges;

 

Step4:Slave连接Master,将node1设置为自己的主服务器

1、查看Master的master-log-file文件和position位置

1 2 3 4 5 6 mysql> show master status; +------------------+----------+--------------+------------------+-------------------+ | File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | +------------------+----------+--------------+------------------+-------------------+ | mysql-bin.000001 |      120 |              |                  |                   | +------------------+----------+--------------+------------------+-------------------+

2、Slave上连接Master,并启动slave

1 2 3 4 5 6 7 8 9 10 mysql>  change master to master_host= '192.168.1.210' , master_user= 'repl_user' , master_password= 'repl_passwd' , master_port=3306, master_log_file= 'mysql-bin.000001' , master_log_pos=120;    mysql> start slave;

3、Slave上查看slave状态(Slave_IO_Running、Slave_SQL_Running和Seconds_Behind_Master

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 mysql> show slave status\G; *************************** 1. row ***************************                 Slave_IO_State: Waiting  for  master to send event                   Master_Host: 192.168.1.210                   Master_User: repl_user                   Master_Port: 3306                 Connect_Retry: 60               Master_Log_File: mysql-bin.000001           Read_Master_Log_Pos: 120                 Relay_Log_File: mysql-relay-bin.000002                 Relay_Log_Pos: 283         Relay_Master_Log_File: mysql-bin.000001               Slave_IO_Running: Yes             Slave_SQL_Running: Yes               Replicate_Do_DB:            Replicate_Ignore_DB:              Replicate_Do_Table:          Replicate_Ignore_Table:        Replicate_Wild_Do_Table: testdb1.%,testdb2.%   Replicate_Wild_Ignore_Table:                      Last_Errno: 0                     Last_Error:                    Skip_Counter: 0           Exec_Master_Log_Pos: 471               Relay_Log_Space: 807               Until_Condition: None                 Until_Log_File:                  Until_Log_Pos: 0             Master_SSL_Allowed: No             Master_SSL_CA_File:              Master_SSL_CA_Path:                Master_SSL_Cert:              Master_SSL_Cipher:                  Master_SSL_Key:          Seconds_Behind_Master: 0

Step5:测试主从同步功能

1、Master上创建数据库和表

1 2 3 mysql> insert into tt1( id ,name) values(1, 'hoai' ),(2, 'dime' );    mysql> create database testdb2;

 

2、Slave上查看是否同步

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 mysql>  select  * from tt1; +------+------+ id    | name | +------+------+ |    1 | hoai | |    2 | dime | +------+------+ 2 rows  in  set  (0.00 sec)       mysql> show databases; +--------------------+ | Database           | +--------------------+ | information_schema | | mysql              | | performance_schema | test                | | testdb1            | | testdb2            | +--------------------+ 6 rows  in  set  (0.00 sec)

清除二进制日志方法(重置主从):

mysql> reset master;

企鹅博客
  • 本文由 发表于 2020年3月19日22:55:13
  • 转载请务必保留本文链接:https://www.qieseo.com/192414.html

发表评论