MySQL主从同步

mysql主从同步

  • 实现数据自动同步的服务结构
  • 主服务器:接受客户端访问连接
  • 从服务器:自动同步主服务器数据到本机

原理示意:


master:binlog日志
slave:包括两个线程

  • Slave_IO:复制master主机binlog日志文件里的SQL命令到本机的relay-log文件里
  • Slave_SQL:执行本机relay-log文件里的SQL语句,实现与master数据一致

配置主从同步(一主一从)

配置master服务器

  1. 启用binlog日志 binlog启用方法
  2. 查看日志信息
  3. 用户授权
mysql> grant replication slave on *.* to USER@'%' identified by 'PASSWORD';

配置slave服务器

  1. 修改主配置文件
  2. 确保与主服务器数据一致
  3. 指定主服务器信息
  4. 启动服务查看状态

修改配置文件

[root@slave ~]vim /etc/my.cnf

[mysqld]
server_id=52    #不允许与主服务器相同
...

同步数据

  • 在主服务器上备份数据,将备份数据拷贝给从服务器
  • 在从服务器使用备份文件恢复数据
  • 在从服务器查看备份文件记录的binlog日志信息
[root@master ~] mysqldump -uroot -pPASSWORD --master-data 数据库名 > /allbak.sql   #--master-data记录当前备份数据对应的日志信息
[root@master ~] scp /allbak.sql root@'从服务器':

[root@slave ~] mysql -uroot -pPASSWORD 数据库名 < /allbak.sql
[root@slave ~] grep binlog日志文件名 /allbak.sql
CHANGE MASTER TO MASTER_LOG_FILE='master51.000001', MASTER_LOG_POS=441;   #指定主服务器需要的信息:binlog日志名和偏移量

指定主服务器信息

[root@slave ~] mysql -uroot -pPASSWORD
mysql> change master to 
 -> master_host="IP",    #主服务器ip地址
 -> master_user="USER",     #主服务器授权用户
 -> master_password="PASSWORD",   #授权用户密码
 -> master_log_file="MASTER_LOG_FILE",   #主服务器正在使用的binlog日志
 -> master_log_pos=MASTER_LOG_POS;   #日志偏移量
 #master信息会自动保存到/var/lib/mysql/master.info文件
 #若更改主服务器信息时,应先执行stop slave; , 修改后再执行start slave; 
mysql> start slave;   #启动slave进程

查看状态(确认IO和SQL线程处于Yes状态)

mysql> show slave status\G;    #这里只写了部分
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.4.51   #主服务器地址
                  Master_User: repluser    #用户名
                  Master_Port: 3306   #主服务器端口
                Connect_Retry: 60
              Master_Log_File: master51.000001
          Read_Master_Log_Pos: 441   
               Relay_Log_File: mysql52-relay-bin.000002     #中继日志relay
                Relay_Log_Pos: 319
        Relay_Master_Log_File: master51.000001
             Slave_IO_Running: Yes    #I/O线程,Yes为运行中
            Slave_SQL_Running: Yes    #SQL线程
                Last_IO_Errno: 0    
                Last_IO_Error:      #IO报错信息
               Last_SQL_Errno: 0    
               Last_SQL_Error:      #SQL报错信息
  Replicate_Ignore_Server_Ids: 
             Master_Server_Id: 51
                  Master_UUID: a6d5ce61-3136-11ea-bc0e-52540042b7a1   #UUID保存在数据库目录下的auto.cnf中
             Master_Info_File: /var/lib/mysql/master.info   #保存master信息的文件
                    SQL_Delay: 0
          SQL_Remaining_Delay: NULL
      Slave_SQL_Running_State: Slave has read all relay log; waiting for more updates

1 row in set (0.00 sec)

相关文件(数据库目录下)

文件名说明
master.info主库信息
relay-log.info中继日志信息
主机名-relay-bin.xxxxxx中继日志(默认只保留2个文件,当第三个文件创建时,会删除第一个文件)
主机名-relay-bin.index索引文件

删除以上文件,重启服务,可以把数据库还原为独立数据库服务器

测试
客户端连接主服务器操作数据,连接从服务器也可以看到相同数据

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值