Mysql双机热备实战

2018年7月12日Otstar Lin

由于跟 Tao.cat 的博主合租一台VPS,但由于Vultr还有余额并且以后会将博客迁出合租的服务器到时候迁移又很麻烦,所以便利用分区解析将国内的流量引到合租服务器,国外流量引到Vultr的服务器,但同步又是个大问题,冷备份会丢数据,所以经过一番思考决定采用热备份的方式同步数据。

由于缓存插件带来了一些大坑,技术欠佳,暂时无法填上,所以博客放弃双机集群

准备工作

  • 两台服务器,建议异地
  • 尽量使用 相同版本 的Mysql
  • 确保两台服务器能互相交流
  • 确保Mysql端口(3306)是通的
  • 尽量先在测试服务器配置成功后再进行业务服务器配置

主服务器A配置

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

强烈建议停用所有业务 因为后面有一步会涉及到动态数据,我第一次配置就是因为数据变化导致启用失败。

停用方案比如 WHMCS 和 WordPress 的维护模式

第二步:导出数据库

命令行或者phpmysql都可以

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

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

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

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

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

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

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

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

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

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

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

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

目的是使同步初始化,该从那行开始执行同步

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

从服务器B配置

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

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

第三步:连接上从服务器B的mysql命令行模式

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

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

下面是一个例子:

第五步:启动 slave

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

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

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

请务必确保 Slave_IO_Running 和 Slave_SQL_Running 的值都是 yes ,就表示成功了,如果任何一个是 NO 那就说明没有成功。博主由于没有将WordPress进入维护模式,所以File和Position数值变化导致启动失败。

第七步:测试是否同步

这步很简单,进入A服务器的phpmyadmin随便改一下数值然后进B服务器查看,若数值变为你更改的数值,即确保A和B处于备份状态。

第八步:双机互相同步

就是将A服务器看作从服务器,B服务器看作是主服务器配置一遍就行。

说点什么

您将是第一位评论人!

avatar
  Subscribe订阅  
提醒
Prev Post Next Post