找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 16727|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi 3 Z5 b7 T: X9 U9 p3 [
主服务器地址:192.168.1.192* W+ `6 S- Q. r) E1 s, k
从数据库地址:192.168.1.193# I; o. R) x: T3 S2 q3 P. `
ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb/ d5 ]2 m. }0 ~0 M+ _

; A& z' f2 m5 t1 U8 t6 o流程:

7 F; e  _5 l' K- Q主服务器3 X) }) l6 T  c- A  I  W
1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:
( j% C( d' Q5 V& Z3 N! W
server-id=1    #服务器 id ( f7 t% B* i* f
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径
8 c1 d9 D4 f% Y( c9 S; rbinlog-do-db=test1    #待同步的数据库
0 |9 M0 [5 O1 X, h; u1 zbinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
! c3 W8 T9 I6 l; r0 X. D; I" Wbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
/ K( F: Y% P& r* i7 T- G! nbinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写
* L; @* P- d1 _4 W/ Z4 [; J
expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)4 Y% l8 z& l6 ?& ~3 D7 P

% s; |. g* Q( x# g/ G; r) U( p2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;% p5 j! E% a3 B; T
; d( s' @7 M" w3 h
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )7 e) D. C  g* p- E5 g! c( k7 g. k

. ^5 p) f" s" H2 ?8 O' i4:给要连接的从服务器设置权限: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即可): Z$ L7 F& M: V9 L8 P. M

3 n+ [$ S. x* F7 [( `5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。% U2 \3 Z6 }4 y, x& X+ b  g

5 b9 Q" p) \5 N- S- O% U6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
! F4 [; t. l$ a0 c% [9 L2 Y
: c2 J; h# s% J9 S0 E
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:' v4 p$ {+ z0 B! ^) ?; [
; `( J) q, _5 [" J, [! c& y" V
1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:

. x% Z; H- l3 M' F$ L! f) a1 g8 D' \server-id=2    #服务器 id ,不能和主服务器一致
0 k. K% l- }" T; u' ?# ~, i+ Jreplicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news1 B2 N5 ?6 c. N1 e6 K- ]
binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写! h% h; q. D/ y- `* q/ h
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
) H- k8 L- x% K5 B9 zbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
" c% I; ?1 F+ k& v+ W2 tbinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

/ r, q$ \4 u6 _8 r1 Wexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
# o6 k1 L3 A5 s# z& p9 F5 Y0 g' o) O# ^% p. i
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
; Z3 I! h  |$ Q. w8 I3 T* r) C3 E
, E0 Y7 z1 ~6 @" \1 X/ t. P; _3 C3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin: ~1 @2 [) U' m+ W

/ L+ |1 H" k5 p7 \# e0 z& e! v4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;' Z9 q$ H% C  l
: V# X+ Z3 g& m9 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线程,然后再设置连接的参数;+ H- B4 a/ C) U2 _9 K( V# S

: Q& v3 Z2 K* e# M4 ?0 m6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes! O2 G: L  ~3 [8 F' S
Slave_SQL_Running: Yes
( T% I  K. m. x+ q' x- s$ g

  x1 t/ Z: Y4 s
& T" R4 _' r; M2 d; c( t: E6 _* S) _7 |7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-6-21 05:37 , Processed in 0.067919 second(s), 24 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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