找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 16535|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi
* W* ~. D4 `( u/ q主服务器地址:192.168.1.192/ N1 \/ D$ M4 {1 K
从数据库地址:192.168.1.193
: z  Q) K/ O( A& `" l9 M0 S2 ?ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb4 q+ `, @9 |3 y; l/ Y+ p: E+ t1 T

5 c- R% v/ j' q0 ~流程:
, ~" x- D& F; H0 f+ I# F& u0 `
主服务器
. r& ], D) }$ l! ^: V) {' e1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:
( u- h8 p, O4 X4 a9 j' L8 X- }
server-id=1    #服务器 id
- {, t; j" L$ l  o0 u2 Z' w# ?log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径. Y# @( m' o+ y) k0 P  v& C2 ?
binlog-do-db=test1    #待同步的数据库
/ o' R/ f. }0 Z" p( }8 ~3 m$ Obinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写9 o, ]8 J1 T5 e1 ~" y
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
( G; U1 k% }# ^, i7 L( J5 {, kbinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写
2 u' d8 J9 b1 D& l: o/ v
expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)0 w! ?0 i0 a: U! v- \& N- o
( I1 z- U+ x  m, N  \
2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;
- L* Y& I% ?; T
. J8 ~- c# o. s- J) m3 t3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )8 G3 M. w2 b' U8 N; T; Z% i: ?

; {. v' u$ v+ C  w- d8 }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即可)" ~$ y9 b2 ?; g  }3 o" N
0 @$ l  X/ a  M* E
5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。8 Y, b- {. @# b- |% c! Y' i
) f& U6 ^$ w, i
6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
5 q6 E9 K: F. F0 ?7 L
0 O9 k% n: t# E* D
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:& H$ E) G" r0 ]. b4 W

) m$ D8 c+ P1 b0 R1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:
9 U- p0 U5 y4 O: G% |5 J* u
server-id=2    #服务器 id ,不能和主服务器一致' O7 ^: \4 b4 Z2 Z3 Z) ]  K: B
replicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
% N$ f! a% E6 Ebinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写9 b& T! o+ B2 W: D1 v7 b, Y0 X" w
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
# ^. s* y! W# I" V( wbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写  m' v# N' e( |2 T- m: m
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写
+ \/ J4 Q- {& x2 b- A. S
expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项); l3 ~9 n! ?/ V0 ]1 T0 C1 n" |

" G3 Y, v8 ^. {6 c+ R2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;6 b8 J, g4 h5 T; F1 I
9 ^) k3 f' l* Z
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin; j( I4 N( n6 _( X! r

- w( @% g. k" E& n9 R  Y) p4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;
: [  c4 Z' [) D0 D4 o6 u& j5 M7 \; ^  X( b4 x- f" g4 ]' E# ~. w3 ~  h
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线程,然后再设置连接的参数;
9 Q# R) @9 s7 V, }4 H; |; v9 L9 H' L8 q2 x' m% V/ I" v( R
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes
( p$ S1 e" F! W& C' f, cSlave_SQL_Running: Yes

# d5 p1 A4 o; E. ~
* b% C! W+ p& m2 _" }* u7 L9 i" n6 i. k8 r! }# z
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-5-31 04:16 , Processed in 0.093469 second(s), 24 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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