找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 14537|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi
% _( d- L  f4 M  u主服务器地址:192.168.1.192
2 D. W3 R- v; C9 q  d5 ^% r从数据库地址:192.168.1.193
: ~; u/ H2 a& Aps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb
5 u" `4 y+ g( T7 H, r6 U* q5 L/ f) i- K' V6 [
流程:

# U& `: b2 a, B) P# i/ X主服务器7 T6 _) W- A7 S: v5 N: l
1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:
6 Y2 w4 i; B' [6 t6 a
server-id=1    #服务器 id . Y; F) J, i( F' ^( F4 l
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径
: j5 W3 P% W" L9 ebinlog-do-db=test1    #待同步的数据库
6 C  D: }+ j8 w7 v  _8 ^binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
  Q" n2 g8 n- a! @8 H$ b% {binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
! ^5 Y( Z- ]  z0 @& Z! vbinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写
6 K0 `6 S) t% ?2 x" ]! {
expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
0 h# B1 a( b6 R. g% e" |# V
) \6 V- |& u, f" t2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;8 V) l& i! K! \1 S+ m0 K
: u! x9 |; ?& I; a5 n/ n/ c- y
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )
! {& f3 t( v8 p. T- {1 Y. t% \/ B" L3 T4 Q" w- [  \
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即可)
2 y7 w; h6 ^% w+ o* \( y& d2 A' D! z7 H% L2 W
5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。1 X' W6 @( N5 q5 |0 |
; @: `/ W! {- M% S& S7 o
6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。

: ]: y4 G) y1 H" q5 V
' }& \( I3 p8 t# @8 G0 F0 g其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
3 @" _5 @* f' m/ X- `
9 j  `1 E; A* j1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:
% I, W8 H2 J2 B' B2 o
server-id=2    #服务器 id ,不能和主服务器一致; t$ ~6 a$ l5 a4 a/ M
replicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
8 `- C% B: x8 C" r4 Z$ v1 Ybinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
5 b$ u& G' T* k  j+ F# I6 u9 ybinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写* N  p6 _8 z4 Z/ j
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写: I6 ~8 C( \+ Y
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写
9 O6 f  A" d* Z4 Z3 \( j9 j
expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
% a3 @6 O! t2 P* r+ c1 ^+ F. [3 w$ Q$ ]
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;0 F3 ^7 T- {: E8 p  H% K
) \) e" V/ Q8 `, h$ I$ |3 o  x; f7 p4 L4 |
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin
8 t, `1 j5 ^1 M) `8 h* E9 z
5 {5 ~8 U  [& K" d" p! c4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;
4 Z: ]8 `; ]8 A+ \; A/ W: k; o, a
( x. @! f5 c7 c) W" h4 b+ y3 `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线程,然后再设置连接的参数;. X5 ~' q( `. c( b6 _4 q! V/ S

- r- l9 r) Y7 C9 q6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes* b/ G& N6 |/ X/ Z: Z5 {9 u/ i
Slave_SQL_Running: Yes
1 i! l% T8 r% i+ ]# b

" E; A  Z( Q2 F1 S1 f! w) B( T) o" i- e9 H( z. T+ L# p7 w
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-29 07:49 , Processed in 0.076484 second(s), 25 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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