找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 15667|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi
8 T- m8 G( _( ?5 {1 b主服务器地址:192.168.1.192
8 L, B1 n  G9 M1 {5 b/ e从数据库地址:192.168.1.193
8 p! _$ K8 e% n. [ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb; e$ y! n: e9 W" U1 A
/ x5 s" J' F* v  l( C8 z, i
流程:
( x. j1 W# C& h! }
主服务器9 n$ n* N) n: S1 t( N
1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:
+ z6 L: t! F2 Q# F. l
server-id=1    #服务器 id - K# J  h, f! V% a' L: w
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径
9 ~& C; t: v; p: U* r; T% L- |binlog-do-db=test1    #待同步的数据库
0 _7 o( ~9 Z% R9 f4 o1 D7 Lbinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写( u* D; B8 J0 q0 M1 `! N
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
8 Z' A6 n/ V% W; {% T5 @* ]% M: mbinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写
( g( _9 G' G+ s5 j7 z
expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项), d- e8 H' ~! f+ x7 ?3 H  V4 \4 O

+ b* h4 V/ \5 ~+ x2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;
% D- q7 d( s+ G9 P, [5 q
/ A" X2 ]; Y  C% Y+ x3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )8 F; L' i3 R( i8 [' a- U+ U  l
0 ?' a9 }. `1 o) J) }) N
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即可)1 [- P8 t! S" n! m; }2 d

4 E  ~5 F! ?, k, ~8 A5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。& Q& w4 G/ k$ k2 E7 _! F
( n6 p& n# ~  e9 t) M5 G! U  p
6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。

0 `# }7 ^  W, j7 e' z# l
- ?- }% K) V5 D  T7 {2 j( p3 n2 _其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:: x3 u1 O% F/ o. r! _  _
2 h: M7 o% L4 l" M9 ~4 d! Q7 n
1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:

; a/ x# L0 ]7 V3 P! P3 h7 S- {server-id=2    #服务器 id ,不能和主服务器一致4 O8 a# w( A0 J9 X. A0 F
replicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news( \* l2 \0 t: K0 k. [
binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
( J& ~! I# G9 k$ hbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写8 E/ D% j' t6 d9 \  w) }8 \
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写% p$ _# C( q/ e3 r
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写
; ^2 i+ d7 g# k4 b" M( p" z, v
expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
8 ]9 d0 p( z. z. f" A8 l
9 `( f) J2 H2 j0 \1 V$ y2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;/ F( J* q  T5 e
! s+ ]. }4 K* L
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin% A( |2 c2 x  U, w  ~' s
: b5 n, E0 S) Z# u% D# Y" ~2 c
4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;: w% V) s& k/ t/ |( e  Y1 ^0 z$ F

2 R- ^# o# n% F* V. E5:修改对主数据库的连接的参数: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线程,然后再设置连接的参数;$ ^+ G. Q7 |/ v! P+ a
& o  |, S" ^! r
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes
/ ~' r5 f( q5 l3 \0 USlave_SQL_Running: Yes

4 s" `6 v- o# D+ U& n6 Z9 Y9 X" P" U" B. w9 [, x" d; n; e

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

点评

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-8 15:25 , Processed in 0.078324 second(s), 25 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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