Windows服务器下MySql数据库单向主从备份详细实现步骤分享

 更新时间:2012年05月28日 09:44:50   作者:  
将主服务器中的MySql数据库同步到从服务器中,使得对主服务器的操作可以即时更新到从服务器,避免主服务器因环境或者网络异常一时无法使用,达到备份效果,这篇文章整理的确实挺详细的
一、目的:将主服务器中的MySql数据库同步到从服务器中,使得对主服务器的操作可以即时更新到从服务器,避免主服务器因环境或者网络异常一时无法使用,达到备份效果。

二、环境:

主从服务器操作系统、数据库版本均相同,具体如下:
操作系统:Windows 2003 Server R2
MySql数据库版本:5.0.51b
主服务器(用A代替)IP地址:192.168.4.100
从服务器(用B代替)IP地址:192.168.4.101

三、配置过程:

1、在A创建远程访问备份账户。
在A的MySql数据库中建立一个备份账户,命令如下:
复制代码 代码如下:

  mysql> GRANT REPLICATION SLAVE,RELOAD,SUPER ON *.* TO july@'192.168.4.101' IDENTIFIED BY '123456';
  mysql> Flush privileges;
  mysql> Quit;


语句解释:

第一句中*.*表示所有数据库,如果要对某个数据库备份的话,假如数据库名称为some,则要换成some.*,其中 TO july@'192.168.4.101',july为远程访问用户名,IP地址为远程访问IP,BY '123456'中123456为远程访问密码;
第二句语句执行后使得远程访问用户创建生效;

执行说明:

执行上述语句后,若要看远程访问用户是否已经创建成功,执行以下语句:
  mysql> use mysql;
  mysql> select host,user from user;
用户列表中多了一条
+------------------------------------+------------------+
|host |user        |
+------------------------------------+------------------+
|192.168.4.101 |july |
+------------------------------------+------------------+
至此,说明远程访问用户已经创建成功。
2、关闭A的MySql服务并拷贝数据到B。
关闭A的Mysql服务,将A中的数据拷贝到B中,使得A、B服务器初始数据完全相同,并且在同步备份之前禁止对服务器中进行数据库写入操作,以保证A、B服务器的初始数据完全相同。
3、修改A中my.ini配置信息
打开my.ini文件,在[mysqld]下添加以下内容(#内容为注释):
  # server-id:A服务器的ID值
  server-id=10
  #log-bin:二进制变更日志
  log-bin=c:\log/log-bin.log
4、重启A服务器。
5、关闭B服务器,对B的my.ini进行相关配置
此处需要注意:
由于设置了slave的配置信息,mysql在数据库data目录下生成master.info,所以如有要修改相关slave的配置要先删除该文件,否则修改的配置不能生效。
打开B的my.ini配置文件,在[mysqld]中添加以下内容:
  #B服务器ID值
  server-id=11
  #远程访问IP地址
  master-host=192.168.4.100
  #远程访问用户名
  master-user=july
  #远程访问用户密码
  master-password=123456
  #主服务器端口(默认为3306,此处要注意主服务器端口是否因为防火墙被禁止)
  master-port=3306
  #同步时间间隔为60秒
  master-connect-retry=60
  #设置要同步备份的数据库,此处数据库为some
  replicate-do-db=some
6、重启B服务器,到此已完成主从备份,如果有错误,可以通过mysql_error.log进行查看。

说明:此文档为网络搜集资料自行试验整理,主要是方便自己后续查找以及有需要者参考,若有侵权之处,联系即删除。

相关文章

  • MySQL如何从不固定位置提取字符串元素详解

    MySQL如何从不固定位置提取字符串元素详解

    这篇文章主要给大家介绍了关于MySQL如何从不固定位置提取字符串元素的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • 解决mysql输入密码闪退的问题

    解决mysql输入密码闪退的问题

    之前安装的mysql一直运行正常,但是在昨天装了个VS2010旗舰版。结果今天mysql就不能用了,于是在网上看了一下最只要就是mysql的服务没有起来的缘故。本文分享了几个解决方案,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-11-11
  • Mysql CPU占用高的问题解决方法小结

    Mysql CPU占用高的问题解决方法小结

    最近发现php网站发布信息比较慢,而且同网站目录下的asp经常登录后立即就重新登录,立即考虑到服务器资源占用问题,所以进服务器看到原来mysql占用率较高 25-60%左右,偶尔能跑到100%,所有导致上述问题的发生
    2012-06-06
  • MySQL迁移到Oracle数据库的超详细步骤和方法总结

    MySQL迁移到Oracle数据库的超详细步骤和方法总结

    今天接到一个任务,让我把MySQL中的表与数据移植到Oracle中,所以这里总结下,这篇文章主要给大家介绍了关于MySQL迁移到Oracle数据库的超详细步骤和方法,需要的朋友可以参考下
    2023-11-11
  • MySQL中LAG()函数和LEAD()函数的使用

    MySQL中LAG()函数和LEAD()函数的使用

    这篇文章主要介绍了MySQL中LAG()函数和LEAD()函数的使用,包括窗口函数的基本用法,LAG()和LEAD()函数介绍,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-08-08
  • MySQL中(JOIN/ORDER BY)语句的查询过程及优化方法

    MySQL中(JOIN/ORDER BY)语句的查询过程及优化方法

    sql语句性能达不到你的要求,执行效率让你忍无可忍,一般会造成很多影响。那么我们如何解决这些问题呢,下面由小编来和大家简单讲下
    2019-05-05
  • MySQL 覆盖索引的优点

    MySQL 覆盖索引的优点

    当索引包含了所有查询的数据时,这个索引就称之为覆盖索引。覆盖索引能够成为一个非常有力的工具并且能够显著改善性能,本文将具体讲述覆盖索引的优点
    2021-05-05
  • 简述MySQL InnoDB存储引擎

    简述MySQL InnoDB存储引擎

    这篇文章主要介绍了MySQL InnoDB存储引擎的相关资料,帮助大家更好的了解MySQL的存储引擎,感兴趣的朋友可以了解下
    2020-08-08
  • Shell下实现免密码快速登陆MySQL数据库的方法

    Shell下实现免密码快速登陆MySQL数据库的方法

    这篇文章主要给大家介绍了在Shell下实现免密码快速登陆MySQL数据库的方法,文中通过示例代码一步步介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面跟着小编来一起看看吧。
    2017-06-06
  • MySQL分区之LIST分区详解

    MySQL分区之LIST分区详解

    mysql分区之LIST分区讲解 MySQL中的LIST分区在很多方面类似于RANGE分区,下面这篇文章主要给大家介绍了关于MySQL分区之LIST分区的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2022-04-04

最新评论