首页 数据库 mysql教程 实现MySQL数据库数据的同步方法介绍_MySQL

实现MySQL数据库数据的同步方法介绍_MySQL

Jun 01, 2016 pm 02:03 PM
master mysql 介绍 同步 实现 方法 服务器

 

做开发的时候要做MySQL的数据库同步,两台安装一样的系统,都是FreeBSD5.4,安装了Apache 2.0.55和PHP 4.4.0,MySQL的版本是4.1.15,都是目前最新的版本。

1. 安装配置

两台服务器,分别安装好MySQL,都安装在 /usr/local/mysql 目录下(安装步骤省略,请参考相关文档),两台服务器的IP分别是192.168.0.1和192.168.0.2,我们把192.168.0.1作为Master数据库,把192.168.0.2作为slave服务器,我们采用单向同步的方式,就是Master的数据是主的数据,然后slave主动去Master哪儿同步数据回来。

两台服务器的配置一样,我们把关键的配置文件拷贝一下,默认的配置文件是在 /usr/local/mysql/share/mysql目录下,分别有 my-large.cnf, my-medium.cnf, my-small.cnf等几个文家,我们只是测试,使用my-medium.cnf就行了。MySQL安装完后,默认的配置文件是指定在数据库存放目录下的,我们用的是4.1.X的,所以配置文件就应该在 /usr/local/mysql/var 目录下,于是把配置文件拷贝过去:

 

1

<ccid_code></ccid_code>cp /usr/local/MySQL/share/MySQL/my-medium.cnf  /usr/local/MySQL/var/my.cnf

登录后复制

两台服务器做相同的拷贝配置文件操作。

2. 配置Master服务器

我们要把192.168.0.1配置为主MySQL服务器(Master),那么我们就要考虑我们需要同步那个数据库,使用那个用户同步,我们这里为了简单起见,就使用root用户进行同步,并且只需要同步数据库abc。

打开配置文件:

 

1

<ccid_code></ccid_code>vi /usr/local/MySQL/var/my.cnf

登录后复制
登录后复制

找到一下信息:

 

1

2

3

4

<ccid_code></ccid_code># required unique id between 1 and 2^32 - 1

# defaults to 1 if Master-host is not set

# but will not function as a Master if omitted

server-id        = 1    //1为Master,2为salve

登录后复制

添加两行:

 

1

2

<ccid_code></ccid_code>sql-bin-update-same     //同步形式

binlog-do-db     = abc  //要同步的数据库

登录后复制

重启192.168.0.1的MySQL服务器:

 

1

2

<ccid_code></ccid_code>/usr/local/MySQL/bin/MySQLadmin shutdown

/usr/local/MySQL/bin/MySQLd_safe --user=MySQL &amp;

登录后复制
登录后复制

3. 配置Slave服务器

我们的slave服务器主要是主动去Master服务器同步数据回来,我们编辑配置文件:

 

1

<ccid_code></ccid_code>vi /usr/local/MySQL/var/my.cnf

登录后复制
登录后复制

找到下面类似的信息:

 

1

2

3

4

<ccid_code></ccid_code># required unique id between 1 and 2^32 - 1

# defaults to 1 if Master-host is not set

# but will not function as a Master if omitted

server-id        = 1

登录后复制

把上面的server-id修改为2,同时添加一些信息:

 

1

2

3

4

5

6

7

8

<ccid_code></ccid_code>server-id                   = 2                        //本MySQL是slave服务器

Master-host             = 192.168.0.1    //Master服务器的IP

Master-user             = root                  //连接Master服务器的用户

Master-password   = ''                        //连接Master服务器的密码

Master-port              = 3306                //连接端口

Master-connect-retry    = 10              //重试次数

replicate-do-db        = abc                  //要同步的数据库

log-slave-updates                              //同步的形式

登录后复制

重启192.168.0.2的MySQL服务器:

 

1

2

<ccid_code></ccid_code>/usr/local/MySQL/bin/MySQLadmin shutdown

/usr/local/MySQL/bin/MySQLd_safe --user=MySQL &amp;

登录后复制
登录后复制

4. 测试安装

首先查看一下slave的主机日志:

 

1

<ccid_code></ccid_code>cat /usr/local/MySQL/var/xxxxx_err (xxx是主机名)

登录后复制

检查是否连接正常, 看到类似这样的信息就成功了

 

1

2

3

4

5

6

7

8

<ccid_code></ccid_code>051031 11:42:40  MySQLd started

051031 11:42:41  InnoDB: Started; log sequence number 0 43634

/usr/local/MySQL/libexec/MySQLd: ready for connections.

Version: '4.1.15-log'  socket: '/tmp/MySQL.sock'  port: 3306  Source distribution

051031 11:42:41 [Note] Slave SQL thread initialized, starting replication in log 'FIRST'

at position 0, relay log './new4-relay-bin.000001' position: 4

051031 11:43:21 [Note] Slave I/O thread: connected to Master 'root@192.168.0.1:3306'

replication started in log 'FIRST' at position 4

登录后复制

在Master查看信息

 

1

<ccid_code></ccid_code>/usr/local/MySQL/bin/MySQL -u root

登录后复制
登录后复制

查看Master状态:

 

1

<ccid_code></ccid_code>MySQL&gt; show Master status;

登录后复制

查看Master下MySQL进程信息:

 

1

<ccid_code></ccid_code>MySQL&gt; show processlist;

登录后复制
登录后复制

在slave上查看信息:

 

1

<ccid_code></ccid_code>/usr/local/MySQL/bin/MySQL -u root

登录后复制
登录后复制

查看slave状态:

 

1

<ccid_code></ccid_code>MySQL&gt; show slave status;

登录后复制

查看slave下MySQL进程信息:

 

1

<ccid_code></ccid_code>MySQL&gt; show processlist;

登录后复制
登录后复制

你再在Master的abc库里建立表结构并且插入数据,然后检查slave有没有同步这些数据,就能够检查出是否设置成功。

最后,如果有兴趣的话,可以研究一下双击热备份,或者一台Master,多台slave的同步实现

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP 的大数据结构处理技巧 PHP 的大数据结构处理技巧 May 08, 2024 am 10:24 AM

PHP 的大数据结构处理技巧

手机版龙蛋孵化方法大揭秘(一步一步教你如何成功孵化手机版龙蛋) 手机版龙蛋孵化方法大揭秘(一步一步教你如何成功孵化手机版龙蛋) May 04, 2024 pm 06:01 PM

手机版龙蛋孵化方法大揭秘(一步一步教你如何成功孵化手机版龙蛋)

手机字体大小设置方法(轻松调整手机字体大小) 手机字体大小设置方法(轻松调整手机字体大小) May 07, 2024 pm 03:34 PM

手机字体大小设置方法(轻松调整手机字体大小)

如何优化 PHP 中的 MySQL 查询性能? 如何优化 PHP 中的 MySQL 查询性能? Jun 03, 2024 pm 08:11 PM

如何优化 PHP 中的 MySQL 查询性能?

如何在 PHP 中使用 MySQL 备份和还原? 如何在 PHP 中使用 MySQL 备份和还原? Jun 03, 2024 pm 12:19 PM

如何在 PHP 中使用 MySQL 备份和还原?

如何选择手机膜,保护你的手机屏幕(选购手机膜的几大要点与技巧) 如何选择手机膜,保护你的手机屏幕(选购手机膜的几大要点与技巧) May 07, 2024 pm 05:55 PM

如何选择手机膜,保护你的手机屏幕(选购手机膜的几大要点与技巧)

如何使用 PHP 插入数据到 MySQL 表中? 如何使用 PHP 插入数据到 MySQL 表中? Jun 02, 2024 pm 02:26 PM

如何使用 PHP 插入数据到 MySQL 表中?

Java 枚举类型在数据库中的应用场景有哪些? Java 枚举类型在数据库中的应用场景有哪些? May 05, 2024 am 09:06 AM

Java 枚举类型在数据库中的应用场景有哪些?

See all articles