找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 15864|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi + T) _6 Z9 B: e& s# b7 Y6 F
主服务器地址:192.168.1.192( B' }- c7 J+ `, B5 P
从数据库地址:192.168.1.193$ I4 U+ m  w& I/ S( F4 [6 {! r
ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb7 J( h- U, s( {$ ^+ M/ d
' `% g+ {; I( L: z8 U
流程:

7 g. Z' o9 ~) O* r% z主服务器
. D/ P8 v) s8 s: E% a, c$ S1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:

) \0 I: S2 D3 u) m7 Xserver-id=1    #服务器 id
1 R3 Z0 A, j3 \7 k! Elog-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径
+ H" w. z1 q. o  Ebinlog-do-db=test1    #待同步的数据库' @! I5 W$ j4 g" L1 S
binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写, R, i, {  x7 y' {+ A
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写2 t# P. a( q' ^3 M; n
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

1 E0 E, R0 m0 v$ e5 p' r8 pexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)( |2 G6 u$ l+ Q; e
1 c( C$ D, n& M9 _) z
2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;1 W: X7 g, [4 i

- S5 ^8 A, k; U7 k# Z# y3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )
. `& H, d5 H8 S2 B6 g& j: h. B% H* L* d: \" F- u4 u3 l1 Q
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即可)
8 o5 s, _0 C2 Y
9 B2 O, [; r9 B5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。- A* [. a0 w  Y

/ v- d- [0 P& z4 T3 n1 \6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
0 O6 Q, o0 c$ [
3 M, M$ @" F" C" I" n
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
3 z3 h( J; b! {# b1 |7 Z- j% A+ s8 J  |
1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:
- l' f, C  l/ M! A& p* Y
server-id=2    #服务器 id ,不能和主服务器一致- j/ ^8 g9 i" d+ S* c
replicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news) X- M# g5 g: l8 F& B- q
binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
1 y* u' R7 W. S5 w0 jbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
3 z( T; m: w- O. q/ @' Z/ @& Rbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写% y8 S! W' p! f) \6 G
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

  M/ F9 b- r! v( ^/ B) K1 g7 Kexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)4 y$ V' Y8 k( N+ w4 }( t$ x

* b4 c2 d$ J* M5 S* p) i* M: ^2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
* w1 H8 P9 p# ]5 i2 a: W6 ~% U- l2 i& f0 W9 l! ~
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin6 ?6 ]" [: O3 a7 ]' h$ G: D7 o' b7 u
5 Q% ~( a" Y+ ], ~) V
4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;
. ~! `2 ^" S9 A" I+ K9 ]# Y% P
7 o& |4 Z! A# T9 g+ ?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线程,然后再设置连接的参数;
, T. D: g4 I) O& z* y) o1 s' y. W. u/ u- S& W0 z% z) t; \) |
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes7 }/ @) N4 }* X& K' B$ M  N; D4 e3 P
Slave_SQL_Running: Yes

8 _! x, A0 R; Z$ L& H7 j; [: Q0 B' G0 o0 n
2 `6 M: ~: m+ a+ h2 y
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-26 06:34 , Processed in 0.080625 second(s), 28 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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