找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 15914|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi / ~7 `5 q) @+ C! [  R9 g2 M
主服务器地址:192.168.1.192
6 T; B1 d# i' \从数据库地址:192.168.1.193# Y& }# E9 n3 i  N
ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb
6 R. |1 Z0 `) J7 C+ ?2 J0 X
7 K5 ?; W7 S; h  x/ s5 N流程:
/ d& _1 f) S5 F, O' Q
主服务器2 H1 B2 ~0 G; @: Q% h, r7 {! x% a
1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:

& u! R& e5 u9 E: Sserver-id=1    #服务器 id / X4 }/ K0 S" J% x# W
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径5 t+ _3 D4 T! ~- @
binlog-do-db=test1    #待同步的数据库
( W( Q5 S6 k- E& ?& vbinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写! }3 v4 C7 \1 n2 e# i
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写0 o% b7 I6 H3 I
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

' J" r4 o& f3 S; o9 zexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
1 I& Y! Z8 O$ x. X
/ v3 K; z& O! J% H' e2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;; O8 \" F* u8 i8 N9 B8 p7 \
; P( ~* e$ ]! g3 o" _; J+ N  }) J
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )
) N' }$ i  B3 ?& Z' d3 G0 I) k7 F) N1 X( Q2 L' F1 ], h
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即可)
- I) p$ n: `, @5 G
8 O  ^$ W1 t: I0 P9 z( N( I4 Y5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。1 h5 z6 r# t9 v4 x4 z* t$ p

+ R! s3 B' ?- }6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。

" ]% L5 f4 |& L4 G* V3 Y6 G
: ^; N; M! v2 }其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
- d( V, q( q; ?% b+ I1 @- f9 B. ], q( @/ [8 n: C" R
1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:

9 u7 T6 Z* `( |$ @server-id=2    #服务器 id ,不能和主服务器一致8 U; V" k" [. ^9 D% Z
replicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
1 k0 I1 W. ~0 H( b- y& U5 R2 o. [binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写1 I5 S$ G& _4 O) W! N5 S) }/ k; @7 z
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写5 }4 D6 B) M5 D; ^, H) _! R
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写) x* m; l, [% z& c' [8 ^% L
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

% e! ~* \: t% D! D6 Cexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)4 t8 w& C" X: _+ v# x7 r

; Z5 o  a7 H: e0 ?1 ?" n2 y, y( k% s) {2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
; w- X) _  C6 z! S5 R$ W% k- B4 O/ m1 O( `: P# b2 b* _
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin
2 v( e6 x2 c1 h3 n" x; G' e% ?" W4 W! O8 W- Y4 J
4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;; @# D- r6 X5 f  ]7 A& F
7 L7 a) y; m9 V7 q, R
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线程,然后再设置连接的参数;
* K% s4 L- u5 Q9 L4 T' n4 o; }% x. `7 G, g1 ]2 W
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes
1 Q- C8 z5 |4 O% p6 T' T3 B8 \Slave_SQL_Running: Yes

! n6 \$ K3 [% R
$ V6 [8 R( K  p( _" [4 j
( C# @7 ~1 g4 _5 B7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-31 06:56 , Processed in 0.082413 second(s), 24 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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