mysql 在线备份的第三方工具 mysql数据实时备份_服务器

专业的SQL Server、MySQL数据库同步软件

以前数据库备份采用的方式一般都是每天定时使用 mysqldump 到处 sql 文件,然后传到异地备份。不过这种定时备份有个问题就是如果服务器出问题了,那么这个备份和实际的业务数据总有一段时间的差异,丢失一部分数据。对于我这样的博客基本每天发一两篇还好,大不了丢一些评论数据,但是像一些 whmcs 做商业业务的,那可就意味着可能丢失一部分商业数据,比如付费数据啥的,那就比较头大了。

所以对于对数据实时性要求比较高的业务, mysql 的数据库的双机热备份就显得比较重要。我也是这两天才摸索着搞起来,把步骤总结下,希望对有需要的同学会有作用。

准备工作

两台服务器。建议异地。

装了 相同版本 的 mysql (为了避免各种不必要的麻烦,强烈建议 mysql 版本务必一致)

Iptables 确保两台服务器的 3306 端口都是通的。

下面为了说明方便,我把要备份的服务器称为”主服务器 A “,把备份服务器称为”从服务器 B “

强烈建议不要直接在业务服务器上操作,先拿测试服务器做好测试,确定走通流程再对业务服务器进行操作

主服务器 A 的相关设置:

第一步:停止所有业务,避免有新的数据库写入

比如 whmcs 和 wordpress 的维护模式

第二步:导出数据库,以便待会导入从服务器

1

mysqldump-u用户-p密码 数据库 > backup.sql

以下是一个事例(假设用户是 root ,密码是 1234 ,需要备份的数据库是 91yun ):

mysqldump-uroot-p1234 91yun > backup.sql

如果你有多个数据库需要备份,就按这命令依序备份。

第三步:修改主服务器 A 的 mysql 配置文件

一般情况,配置 mysql 的位置文件在/etc/my.cnf

在 [mysqld] 标签下增加以下内容

log-bin=mysql-bin
binlog_format=mixed
server-id =1
read-only=0
binlog-do-db=91yun
auto-increment-increment=10
auto-increment-offset=1
log-bin=mysql-bin # 一般配置文件已经自带了,就是开启日志
binlog_format=mixed # 一般配置文件自带了

server-id=1 # 这个需要特别注意下,每个服务器都需要配置不同的 ID ,这里我们把主服务器设成 1 ,后面的从服务器我们就要设置成 2 了

read-only=0

binlog-do-db=91yun # 这里是要备份的数据库,如果要备份多个数据库可以重复多行 , 这里的意思就是我要备份 91yun 这个数据库

auto-increment-increment=10 # 这个数字是假设有 10 台服务器进行互相备份,影响一些自增长字段的自增长量

auto-increment-offset=1 # 这个 确保每个服务器不同 ,并不高于上面这个参数,影响自增长字段的自增长量

设置完后请重启 mysql 服务,以便设置生效 service mysql restart

第四步:在主服务器 A 连上 mysql

1

mysql-u用户-p密码

mysql 的连接命令为 mysql-uroot -p1234 ( 这里假设用户是 root ,密码是 1234) 需要注意的是, u 和用户, p 和密码之间并没有空格。

第五步:在主服务器 A 上创建用于备份的用户

该命令需要在上步连接 mysql 后,运行于 mysql 的命令行模式

1

grant replication slave on *.* to ‘用户名’@’从服务器B的IP’ identified by ‘用户密码’;

需要在把上面命令的用户名,密码和从服务器的 IP 换成你自己的。下面是一个例子:

grant replication slave on *.* to ‘slave1’@’192.168.3.2’ identified by ‘IHEnZ1y6J6’;

该命令的意思就是:创建一个用于备份的用户,用户名是 slave1 ,密码是 IHEnZ1y6J6 ,这个用户只允许从 192.168.3.2 这个 IP 的机子上登陆

需要注意的是, mysql 的所有命令都是以分号结尾的 ;

第六步:取得主服务器 A 的 mysql 目前的状态

该命令也是运行于 mysql 的命令行模式

1

show master status\G

请记下这个 File 和 Position 的内容!

下面开始修改从服务器 B 相关的设置

第一步:导入刚才 A 服务器到处的 Sql

这一步主要是确保两台服务器数据库的初始状态是一样的,如果这两个数据库已经一样了,那就可以略过了。

一般导入的数据库的命令:

1

mysql-u用户-p密码 数据库
下面是一个例子(假设用户是 root ,密码是 1234 ,导入的数据库是 ss100 )
mysql-uroot-p1234 ss100
binlog_format=mixed
server-id =2
replicate-do-db=91yun
relay_log=mysqld-relay-bin
log-slave-updates=ON
log-bin=mysql-bin # 一般默认都有了,开启 log
binlog_format=mixed # 一般默认也有了,格式
server-id=2 # 需要注意这个,因为主服务器设置了 1 ,所以这里我们就设成 2
replicate-do-db=91yun # 这个是需要复制的数据库
relay_log=mysqld-relay-bin # 这行照抄,不用改
log-slave-updates=ON
第三步:连接上从服务器 B 的 mysql 命

令行模式

1

mysql-u用户-p密码

进入 mysql 命令行模式

第四步:给从服务器 B 设置主服务器的相关信息

在命令行模式下运行下列命令:

1

CHANGE MASTER TO MASTER_HOST=’主服务器A的IP’, MASTER_USER=’备份的用户名’, MASTER_PASSWORD=’用户密码’, MASTER_LOG_FILE=’主服务器的File’,MASTER_LOG_POS=主服务器A的Position;
MASTER_HOST # 主服务器 A 的 IP
MASTER_USER # 刚才在从服务器 A 上设置过的用于备份的用户名
MASTER_PASSWORD # 刚才在服务器 A 上设置过的用户的密码
MASTER_LOG_FILE # 刚才主服务器 A 上最后一步让大家记住的主服务器 A 状态的 File
MASTER_LOG_POS # 刚才主服务器 A 上最后一步让大家记住的主服务器 A 状态的 Position;

以下是一个例子:

CHANGE MASTER TO MASTER_HOST=’192.168.3.1′, MASTER_USER=’slave1′, MASTER_PASSWORD=’IHEnZ1y6J6′, MASTER_LOG_FILE=’mysql-bin.000005′,MASTER_LOG_POS=449;

第五步:启动 slave

在 mysql 的命令行模式下输入:

1

start slave;

第六步:查看从服务器是否正常运行

在 mysql 的命令行模式下,运行以下命令:

1

show slave status\G

请务必确保 Slave_IO_Running 和 Slave_SQL_Running 的值都是 yes ,就表示成功了,如果任何一个是 NO 那就说明没有成功。

比较常见的错误是防火墙的设置导致 3306 连不上。请确保 iptables 设置正确或者关闭。

第七步:测试是否同步

你现在可以通过 phpmyadmin 在服务器 A 里面随便改个字段或者加个内容,看看从服务器 B 是否有相应的变化。

如果你需要 B 同时也具有写入功能,那你就把服务器 B 作为 master 主服务器, A 作为从服务器,按上面步骤从新再来一遍。那就可以确保 A 和 B 处于互相备份状态。