实现MySQL数据库同步大演练

数据库 MySQL
今天主要向大家描述的是实现MySQL数据库同步的实际操作步骤与其在实际操作中应注意的事项的具体描述,以下就是文章的详细内容描述。

我们今天向大家介绍的是实现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文件则取该配置文件。当运行MySQL\bin\winMySQLadmin.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.增加一个用户最为同步的用户帐号:

 

 

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

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

  1. create database backup  

B:设置

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

 

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

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

  1. create database backup 

 

 

主从模式:A->B

 

A为master

 

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

 

server-id=1

 

log-bin

 

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

 

#其中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:\MySQLlog\MySQLlog

 

binlog-do-db=backup

 

 

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

 

 

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

 

 

测试:

 

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

 

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

 

但是我的MySQL是5.1.30-win32的,安装后在C:\Program Files\MySQL\MySQL 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/

【编辑推荐】

  1. IPTV会否是分众购对象
  2. 我国IPTV研究目全球领先
  3. 3G与IPTV是发展大方向
  4. 我国IPTV研究目全球领先
  5. 3G与IPTV是发展大方向

 

责任编辑:佚名 来源: 博客园
相关推荐

2010-06-02 16:57:50

MySQL数据库同步

2010-06-09 17:36:45

MySQL数据库同步

2020-09-21 11:30:28

CanalMySQL数据库

2010-05-26 18:16:31

MySQL数据库安装

2010-08-27 09:59:51

SQL Server

2010-05-12 18:41:34

MySQL数据库

2010-06-09 14:04:34

MySQL数据库

2020-08-31 07:00:00

数据库数据库同步

2010-05-04 14:57:27

Oracle数据库

2011-07-13 16:19:54

存储过程SQL Server数

2011-03-23 10:21:10

jQuery

2010-06-12 17:55:23

MySQL数据库同步

2009-04-13 13:55:26

MySQL数据库主机同步

2010-05-27 15:56:56

MySQL数据库

2019-09-05 09:17:37

MySQL数据库线程

2010-07-02 08:39:02

SQLServer数据

2010-05-20 10:10:30

MySQL数据库同步

2010-05-17 14:00:07

MySql数据库

2010-11-03 08:41:55

MySQL

2010-05-19 16:31:38

MySQL数据库
点赞
收藏

51CTO技术栈公众号