当前位置:首页 > 系统运维 > 正文内容

实现MySQL数据库同步大演练

a8116255316年前 (2010-06-09)系统运维7

我们今天向大家介绍的是实现MySQL数据库同步的实际操作步骤,以及在实际操作值得我们大家注意的事项的描述, 我最进在网上找了一下实现MySQL数据库同步的实际操作步骤,大家都说的是这样:

“ MySQL从3.23.15版本以后提供数据库复制功能。利用该功能可以实现两个MySQL数据库同步,主从模式,互相备份模式的功能。

MySQL数据库同步复制功能的设置都在MySQL的设置文件中体现。MySQL的配置文件(一般是my.cnf)

在unix环境下在/etc/MySQL/my.cnf 或者在MySQL用户的home目录下面的my.cnf.

window环境中,如果c:根目录下有my.cnf文件则取该配置文件。当运行MySQLbinwinMySQLadmin.exe工具时候,该工具会把c:根目录下的my.cnf 命名为mycnf.bak。并在winnt目录下创建my.ini。MySQL服务器启动时候会读该配置文件。所以可以把my.cnf中的内容拷贝到my.ini文件中,用my.ini文件作为MySQL

服务器的配置文件。

设置 *** :

设置范例环境:

操作系统:window2000 professional

MySQL:4.0.4-beta-max-nt-log

A ip:10.10.10.22

B ip:10.10.10.53

A:设置

1.增加一个用户最为同步的用户帐号:

GRANT FILE ON *.* TO backup@'10.10.10.53' IDENTIFIED BY ‘1234’  

2.增加一个数据库作为同步数据库:

create database backup  

B:设置

1.增加一个用户最为同步的用户帐号:

GRANT FILE ON *.* TO backup@'10.10.10.22' IDENTIFIED BY ‘1234’  

2.增加一个数据库作为MySQL数据库同步:

create database backup 

主从模式:A->B

A为master

修改A MySQL的my.ini文件。在MySQLd配置项中加入下面配置:

server-id=1

log-bin

#设置需要记录log 可以设置log-bin=c:MySQLbakMySQLlog 设置日志文件的目录,

#其中MySQLlog是日志文件的名称,MySQL将建立不同扩展名,文件名为MySQLlog的几个日志文件。

binlog-do-db=backup #指定需要日志的数据库

重起数据库服务 

用show master status 命令看日志情况。

B为slave

修改B MySQL的my.ini文件。在MySQLd配置项中加入下面配置:

server-id=2

master-host=10.10.10.22

master-user=backup #同步用户帐号

master-password=1234

master-port=3306

master-connect-retry=60 预设重试间隔60秒

replicate-do-db=backup 告诉slave只做backup数据库的更新

重起数据库 

用show slave status看同步配置情况。

注意:由于设置了slave的配置信息,MySQL在数据库目录下生成master.info

所以如有要修改相关slave的配置要先删除该文件。否则修改的配置不能生效。

双机互备模式

如果在A加入slave设置,在B加入master设置,则可以做B->A的同步。

在A的配置文件中 MySQLd 配置项加入以下设置:

master-host=10.10.10.53

master-user=backup

master-password=1234

replicate-do-db=backup

master-connect-retry=10

在B的配置文件中 MySQLd 配置项加入以下设置:

log-bin=c:MySQLlogMySQLlog

binlog-do-db=backup

注意:当有错误产生时*.err日志文件。同步的线程退出,当纠正错误后要让同步机制进行工作,运行slave start

重起AB机器,则可以实现双向的热备。

测试:

向B批量插入大数据量表AA(1872000)条

AMySQL数据库同步每秒钟可以更新2500条数据。”

但是我的MySQL是5.1.30-win32的,安装后在C:Program FilesMySQLMySQL Server 5.1这个文件夹里根本就没有my.cnf,只有my.ini,有些说要用winMySQLadmin.exe压运行这个文件后就会在c盘的根目录下有一个mycnf.bak文件,同时在C:WINDOWS文件夹里生成一个my.ini文件。

但是我安装了并运行了winMySQLadmin.exe之后,在c盘的根目录下根本就没有一个mycnf.bak文件,我在整个电脑里都没有找到这个文件。不知道我哪里没有做对,忘高手们指点一二。帮助后给高分。

原文标题:MySQL数据库同步

连接:http://space.cnblogs.com/question/6586/

扫描二维码推送至手机访问。

版权声明:本文由2345好导航站长资讯发布,如需转载请注明出处。

本文链接:http://2345hao.cn/blog/index.php/post/20975.html

分享给朋友:

“实现MySQL数据库同步大演练” 的相关文章

windows 7/8.1正在启动windows时间长的解决方法

windows 7/8.1正在启动windows时间长的解决方法

正在启动windows时间长怎么办 小编带来了Windows 7/8.1正在启动windows时间长解决方法,假如有朋友在安装完Windows系统之后一直停留在“正在启动windows”的话,不妨试一试下文的方法哦~ 原因:Windows 7/8.1不完全支持UEFI,需要CSM(Comp...

windows 7系统如何设置休眠时不断网以便继续完成下载

windows 7系统如何设置休眠时不断网以便继续完成下载

在Windows 7系统的默认设置中,当Windows 7系统处于休眠状态时,会同时断网的。如此一来,无论你正在使用迅雷还是快车等下载工具,同样可以在休眠状态下继续完成下载,最大限度做到从身边的小事开始支持环保。下面我们就详细介绍操作步骤,帮助Windows 7系统用户实现这一节能目标。 首先需要...

解决windows 7无法将程序锁定到任务栏或附到开始菜单的方法

解决windows 7无法将程序锁定到任务栏或附到开始菜单的方法

出现该问题的原因是由于使用第三方优化软件消除快捷方式的小箭头引起的。 1、在开始搜索框中键入“regedit”,按回车键打开注册表编辑器。 2、依次定位到以下分支:HKEY_CLASSES_ROOTlnkfile。 3、在lnkfile项上鼠标右键单击“新建”——“字符串值”。...

windows 7系统开机后出现黑屏提示Windows无法启动

windows 7系统开机后出现黑屏提示Windows无法启动

一些用户的Windows 7系统开机后出现黑屏,代码为 Windows无法启动: WindowsSystem32ConfigSystem”。这个问题该如何修复呢?现在小编就给大家分析一下吧。 其实这个代码的意思是引导文件丢失了,引导文件(NTLDR)一般存放于C盘根目录下,是一个具有隐藏和只读属性...

windows 7如何给c盘扩容 图解windows 7 64位系统C盘扩容方法(自

windows 7如何给c盘扩容 图解windows 7 64位系统C盘扩容方法(自

用Windows 7久了,C盘越来越大,原来50G的空间基本用完了,又不想重装系统,就想着能不能直接扩容。 在网上搜了半天,看了无数教程,都写得不明不白的,结合了几篇教程才终于搞明白。 重新总结一下,方便有需要的人。 所用软件: http://www.jb51.net/softs/57895...

windows 7系统怎么取消禁ping命令?

windows 7系统怎么取消禁ping命令?

当我在虚拟机的linux系统中ping本机的ip发现ping不通,而本机可以ping通虚拟机中的ip。应该是出于安全考虑吧,Windows 7默认在防火墙里禁止了。 1、查看主机ip 打开“开始”程序中的“附件”,找到“命令提示符”打开。输入命令:ipconfig,可以看到本机的ip是192.1...