Mysql的主从复制

实现主从复制原理:

在主服务器(master)上

启用二进制日志 选择一个唯一的server-id 创建具有复制权限的用户

在从服务器(slave)上

启用中继日志 (二进制日志可开启,也可不开启) 选择一个唯一的server-id 连接至主服务器,并开始复制

实战准备:两台虚拟机,一主一从。

主库(MySQL Master):[ip为192.168.10.130 port为3306]

从库(MySQL Slave ):[ip为192.168.95.139 port为3306]

主库配置

1)设置server-id值并开启binlog参数

[mysqld]

log_bin = mysql-bin

server_id = 130

重启数据库

2)建立同步账号

creat user 'rep1'@'192.168.10.139' identified with mysql_native_password by 'Test@1234'#设置账户密码

grant replication slave on *.* to 'rep1'@'192.168.10.139';  #给权限

grant replication slave on *.* to 'rep1'@'192.168.10.139';  # replication

show grants for 'rep1'@'192.168.10.139';

3)锁表设置只读

为后面备份准备,注意生产环境要提前申请停机时间;

mysql> flush tables with read lock;

提示:如果超过设置时间不操作会自动解锁。

mysql> show variables like '%timeout%';

测试锁表后是否可以创建数据库:

4)查看主库状态 查看主库状态,即当前日志文件名和二进制日志偏移量

mysql> show master status;

 记住file和position,方便slave后续连接。

5)备份数据库数据

# mysqldump -uroot -p -A -B |gzip > mysql_bak.$(date +%F).sql.gz

6)解锁

mysql> unlock tables;

 7)主库备份数据上传到从库

# scp /server/backup/mysql_bak.2022-09-12.sql.gz 192.168.10.139:/root/hh     //在从设备上建立新目录hh

从库上设置

1)设置server-id值并关闭binlog参数

#log_bin = /data/mysql/data/mysql-bin

server_id = 139

重启数据库:

2)还原从主库备份数据

# cd /server/backup/

# gzip -d mysql_bak.2022-09-12.sql.gz

# mysql -uroot -p < mysql_bak.2022-09-12.sql

检查还原:

# mysql -uroot -p -e 'show databases;'

3)设定从主库同步

mysql> change master to
    -> master_host='192.168.10.130',
    -> master_port=3306,
    -> master_user='rep1',
    -> master_password='Test@1234',
    -> master_log_file='mysql-bin.000006',
    -> master_log_pos=157;

4)启动从库同步开关

mysql> start slave;

检查状态:

mysql> show slave status\G

 两个yes,表示主备复制功能达成。

下面进行测试:

在192.168.10.130(主)上执行:

create databses data;  新建数据库

 同样查看从虚拟机上也建好了data文件,实现了Mysql的主从复制。

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值