找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 16785|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi 0 G) }' D+ N2 i5 \1 m
主服务器地址:192.168.1.1928 V! Z+ b- [) ^% d
从数据库地址:192.168.1.1939 m- [3 A. N. o
ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb
, c+ E/ t! i+ W) p& {7 w) Z, p9 f9 m- f8 _
流程:
+ q0 b0 v3 ]; W+ Q% c8 E
主服务器& E- M# Q: V& d* n7 P% F% J' c
1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:

* K: @" I7 ?3 s% Zserver-id=1    #服务器 id ) b4 n* H* }) B5 l2 q' r
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径
7 D' r+ x& O0 _! Zbinlog-do-db=test1    #待同步的数据库+ r) e" @7 M1 V0 f# x
binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写. V* s  o7 ~# c9 r" p4 Z
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
' G5 e0 {2 r8 d- x9 G4 Fbinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写
8 _/ i, s8 n3 s% S" s* m
expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)' m' C  a7 f; h9 d! ?  y# @  i6 l
$ I) `, Y; \( x6 G0 ^, S7 _0 a
2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;( \# l; g+ q$ V* Y
; y4 \9 H& u( L) F1 B" \( C
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )& o5 @' }6 }* j( x: Q
* D* O$ i! j' N  ]" Z
4:给要连接的从服务器设置权限:grant replication slave,reload,super on *.* to slavetb@192.168.1.193 identified by '123456';     ps: 给主机192.168.1.193添加权限,用户名:slavetb,密码:123456;注意不要少了;号(只需输入一次就可以了,向数据库中插入一个具有同步权限的帐号,可在phpmyadmin中设置,全局权限管理项选中RELOAD, SUPER, REPLICATION SLAVE即可)
! S& T8 K/ n4 @9 H6 n8 H0 S) @. A2 L  e- T6 b
5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。6 \" W. e: B) d8 u

% m$ o* o" Z6 L' o* y8 f8 _6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
  P9 v. i: o3 f7 E( U
- g3 J! h/ F% w
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:4 A" ?: B9 }6 y2 D

0 g, {- p/ p& m9 Y: V; B( ~1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:
$ n4 {6 U6 g( B
server-id=2    #服务器 id ,不能和主服务器一致0 ?$ z5 r) z, r8 o; Y( \8 S: _
replicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
4 K! I8 A; Q8 i+ I/ t# @( L) Ubinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
# t0 A4 M, g, ~* _4 @& x( Ebinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写4 V" F( q& k- u8 Y( Z
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
% l% u, n0 y$ W) hbinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

6 ^' q" d8 K' Z6 c' c0 N. Gexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)8 W' d" K3 A4 q( E" [4 H

, _7 y4 u* K  ]2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
( X; |( }7 w9 ~  T2 V, |' k9 s& @7 [# @" X' a( o
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin5 V5 j) o9 z& U, {% T+ H8 l' u

2 s6 C- R# _# {$ m; L4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;
& H0 }2 M5 H3 r7 }0 j' u4 ]/ W2 s, a6 b. C8 B
5:修改对主数据库的连接的参数:mysql>change master to master_host='192.168.1.193',master_user='slavetb',master_password='1234562', master_log_file='mysql-bin.000001',master_log_pos=107;  ps:最后两个中
mysql-bin.000001与107为主服务器配置中第5步记录下来的值。可能会报一个错误,大概的意思是说slave线程正在运行,不能设置,这样的话,执行mysql>stop slave; 停止slave线程,然后再设置连接的参数;8 Z0 X8 @& L& W; u

( K2 a) B( l7 W% e( I. R6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes- h$ V7 M4 I$ Y- x( u; K
Slave_SQL_Running: Yes
% b9 N* F" C; S8 M

- f* G2 |; l+ r: [4 Y
4 x; b+ q# L* p; z- e1 Q7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

的确  发表于 2013-4-1 01:07
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|第一站论坛 ( 蜀ICP备06004864号-6 )

GMT+8, 2026-6-25 12:46 , Processed in 0.061454 second(s), 22 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表