您好,欢迎访问一九零五行业门户网

MYSQL 数据库同步

最近要做数据库同步,如果网上找了例子,成功,记录下来,下回再看. 这个是网上找的一编文章. 以下配置在本机上已经成功: 实现功能:a为主服务器,b为从服务器,初始状态时,a和b中的数据信息相同,当a中的数据发生变化时,b也跟着发生相应的变化,使得a和b的数
最近要做数据库同步,如果网上找了例子,成功,记录下来,下回再看.
这个是网上找的一编文章.
以下配置在本机上已经成功:
实现功能:a为主服务器,b为从服务器,初始状态时,a和b中的数据信息相同,当a中的数据发生变化时,b也跟着发生相应的变化,使得a和b的数据信息同步,达到备份的目的。
环境:
a、b的mysql数据库版本同为4.1.20
a:
操作系统:windows 2003 server
ip地址:192.168.100.1
b:
操作系统:windows 2003 server
的ip地址:192.168.100.2
配置过程:
1、在a的数据库中建立一个备份帐户,命令如下:
grant replication slave,reload,super on *.*
to backup@'192.168.100.2'
identified by ‘1234’;
建立一个帐户backup,并且只能允许从192.168.100.2这个地址上来登陆,密码是1234。
2、因为mysql版本新密码算法不同,所以进入mysql下,输入:set password for 'backup'@'192.168.100.2'=old_password('1234');
3、关停a服务器,将a中的数据拷贝到b服务器中,使得a和b中的数据同步,并且确保在全部设置操作结束前,禁止在a和b服务器中进行写操作,使得两数据库中的数据一定要相同!
4、对a服务器的配置进行修改,打开mysql/my.ini文件,在[mysqld]下面添加如下内容:
server-id=1
log-bin=c:log-bin.log
server-id:为主服务器a的id值
log-bin:二进制变更日值
5、重启a服务器,,从现在起,它将把客户堆有关数据库的修改记载到二进制变更日志里去。
6、关停b服务器,对b服务器锦熙配置,以便让它知道自己的镜像id、到哪里去找主服务器以及如何去连接服务器。最简单的情况是主、从服务器分别运行在不同的主机上并都使用着默认的tcp/ip端口,只要在从服务器启动时去读取的mysql/my.ini文件里添加以下几行指令就行了。
[mysqld]
server-id=2
master-host=192.168.100.1
master-user=backup
master-password=1234
//以下内容为可选
replicate-do-db=backup
server-id:从服务器b的id值。注意不能和主服务器的id值相同。
master-host:主服务器的ip地址。
master-user:从服务器连接主服务器的帐号。
master-password:从服务器连接主服务器的帐号密码。
replicate-do-db:告诉主服务器只对指定的数据库进行同步镜像。
7、重启从服务器b。至此所有设置全部完成。更新a中的数据,b中也会立刻进行同步更新。如果从服务器没有进行同步更新,你可以通过查看从服务器中的mysql_error.log日志文件进行排错。
8、由于设置了slave的配置信息,mysql在数据库data目录下生成master.info,所以如有要修改相关slave的配置要先删除该文件,否则修改的配置不能生效。
如果要两台同时同步的话,只要server-id不同就行了.如果同步失败,可以用下面的语句来查看.
1.show master statusg; 查看主机情况.
2.show slave statusg; 从机情况.
如果两台的id和文件不同,可以用下面的语句更正.
change master to master_def [, master_def] ...
master_def:
master_host = 'host_name'
| master_user = 'user_name'
| master_password = 'password'
| master_port = port_num
| master_connect_retry = count
| master_log_file = 'master_log_name'
| master_log_pos = master_log_pos
| relay_log_file = 'relay_log_name'
| relay_log_pos = relay_log_pos
来源:
其它类似信息

推荐信息