mysql 数据库双机热备份

mysql 数据库双机热备份

1. 环境准备

  1. 两台纯净的centos6 linux系统
  2. 两台linux虚拟机都安装mysql数据库
  3. 前提条件,两台机器可以ping通

名词解释

  • 主服务器(master):负责日常服务器的增、删、改、查任务,是数据库集群的主力者。
  • 从服务器(slave):负责服务器上热备份数据,若主服务器崩溃或人为不可抗拒的灾难,可暂时替代主服务器继续提供数据。
  • 热备份(hot backup):指系统运行时进行的备份操作,在备份过程中,系统不会停止服务,数据被实时或准实时地复制到备份存储中。
  • 冷备份(cold backup):指系统关闭或不运行时进行的备份操作,在备份过程中,系统服务被停止,数据被复制到备份存储中。成本较低。

2. 主从复制

环境描述

主服务器master:192.168.111.136
从服务器slave:192.168.111.137
MySQL 用户:replicate
MySQL 用户密码:root
两台机器同时操作,可以使用 MobaXterm_CHS 连接虚拟机,便于操作

在这里插入图片描述

关闭防火墙

service iptables stop

安装mysql

# 解压mysql安装包,主从服务器mysql版本保持一致
cd /home
tar -xvf MySQL.rpm-bundle.tar

# 安装数据库
rpm -ivh MySQL-*rpm --nodeps --force 

启动mysql,登录mysql

service mysql start

# 首次登录不需要密码,直接enter
mysql -uroot -p
# 授权root并修改密码为root
grant  all privileges on  *.* to 'root'@'localhost' identified by 'root';
# 仅修改密码:alter user 'root'@'localhost' indentified by 'root';
flush privileges;

改成对应的静态ip

cd /etc/sysconfig/network-scripts/

cat ifcfg-eth0
# 如下内容
DEVICE=eth0
HWADDR=00:0C:29:6D:7A:FD
TYPE=Ethernet
UUID=859d5289-7bf4-423f-aad4-dd2f4a0becbb
ONBOOT=no
NM_CONTROLLED=yes
BOOTPROTO=dhcp

vi ifcfg-eth0
# 改成
DEVICE=eth0
HWADDR=00:0C:29:6D:7A:FD
TYPE=Ethernet
UUID=859d5289-7bf4-423f-aad4-dd2f4a0becbb
ONBOOT=yes
NM_CONTROLLED=yes
BOOTPROTO=static
IPADDR=192.168.111.137
NETMASK=255.255.255.0
GATEWAY=192.168.111.1
DNS1=8.8.8.8
DNS2=8.8.4.4

# 重启网络
sudo systemctl restart network
主服务器master配置

进入192.168.111.136,进入mysql,创建同步用户replicate,授权复制(replication)从属(slave)权限,并指定从服务器ip以及密码为root

# 主服务器创建用户
grant replication slave on *.* to  'replicate'@'192.168.111.137' identified by  'root';
flush privileges;
# 在从服务器192.168.111.137 上测试
mysql -h192.168.111.136 -ureplicate -proot;

修改主服务器 mysql 配置文件

vi /etc/my.cnf
# 添加如下内容
[mysqld]
server-id=1
log-bin=mysql-bin
binlog-do-db=test
binlog-ignore-db=mysql

重启mysql服务

service mysql restart

查看主服务器状态

# 进入mysql服务
mysql -uroot -proot

# 刷新表的读取锁
flush tables with read lock;

# 查看主服务器的状态
show master status\G;

# 解锁表
unlock tables;

注意记录:File(日志编号)和 Position(位置)两个参数,用于从服务器配置主从关系时用到。

从服务器slave配置

进入192.168.111.137,修改从服务器 mysql 配置文件

vi /etc/my.cnf
# 添加如下内容
[mysqld]
server-id=2
log-bin=mysql-bin
replicate-do-db=test
replicate-ignore-db = mysql,information_schema,performance_schema

重启mysql服务

service mysql restart

进入mysql,用change master指定同步位置

# 先停止slave服务线程
stop slave;

# 指定同步位置
change master to master_host='192.168.111.136',
master_user='replicate',
master_password='root',
master_log_file='mysql-bin.000001',
master_log_pos=107;
# master_host 主服务ip
# master_user 同步用户
# master_log_file File日志编号
# master_log_pos Position位置

# 刷新权限
flush privileges;

查看从服务器状态

show slave status\G;

# Slave_IO_Running: Yes
# Slave_SQL_Running: Yes
# 表示设置成功

sql语言不区分大小写。

测试同步

在主服务器中,进入mysql,创建表,插入数据

use test;
create table tb_mobile(mobile varchar(20), time timestamp default now())
insert into tb_mobile (mobile) values('13456789898');

在从服务器中,进入mysql,查看是否同步成功

use test;
select * from tb_mobile;

现在从服务器可以同步主服务器,但是主服务器无法同步从服务器的操作,接下来,进行主主复制配置。
即主从为单向复制,主主为双向复制。

3. 主主复制

环境描述:和主从复制时一致,可以完成主从复制后,进行主主复制,二者不影响,不过以防万一,可以先打个快照。

服务器 A:192.168.111.136
服务器 B:192.168.111.137
MySQL 用户:replicate
MySQL 用户密码:root
服务器 A 配置(192.168.111.136)

编辑 MySQL 配置文件

vi /etc/my.cnf
# 如下配置
[mysqld]
server-id=1
log-bin=mysql-bin
binlog-do-db=test
binlog-ignore-db=mysql,information_schema,performance_schema

# 添加以下配置以启用复制过滤器
replicate-do-db=test
replicate-ignore-db=mysql,information_schema,performance_schema

创建复制用户:

create user 'replicate'@'%' identified by 'root';
grant replication slave on *.* to 'replicate'@'%';
flush privileges;
# %代表任何主机

记录二进制日志文件名和位置:

show master status;
服务器 B 配置(192.168.111.137)

编辑 MySQL 配置文件:

vi /etc/my.cnf
# 如下配置
[mysqld]
server-id=2
log-bin=mysql-bin
binlog-do-db=test
binlog-ignore-db=mysql,information_schema,performance_schema

# 添加以下配置以启用复制过滤器
replicate-do-db=test
replicate-ignore-db=mysql,information_schema,performance_schema

创建复制用户:

create user 'replicate'@'%' identified by 'root';
grant replication slave on *.* to 'replicate'@'%';
flush privileges;

记录二进制日志文件名和位置:

show master status;
配置双向复制

在服务器 A(192.168.111.136)上设置从服务器(指向服务器 B)

从服务器 B 获取二进制日志文件名和位置,然后在服务器 A 上执行以下命令:

change master to
master_host='192.168.111.137',
master_user='replicate',
master_password='root',
master_log_file='mysql-bin.000001',  -- 使用服务器 b 上实际的日志文件名
master_log_pos=107;  -- 使用服务器 b 上实际的日志位置

start slave;

在服务器 B(192.168.111.137)上设置从服务器(指向服务器 A)

从服务器 A 获取二进制日志文件名和位置,然后在服务器 B 上执行以下命令:

change master to
master_host='192.168.111.136',
master_user='replicate',
master_password='root',
master_log_file='mysql-bin.000001',  -- 使用服务器 a 上实际的日志文件名
master_log_pos=107;  -- 使用服务器 a 上实际的日志位置

start slave;
验证复制状态

在服务器 A 和 B 上验证复制状态

show slave status\G;

检查 Slave_IO_RunningSlave_SQL_Running 是否均为 Yes,以及是否存在任何错误。

分别在服务器A和服务器B中,插入输入,查看数据库是否同步

use test;
insert into tb_mobile (mobile) values('13456789898');
select * from tb_mobile;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

物往fd

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值