找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 13280|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi
3 X5 L; ~, N; r, }1 e9 ~" t主服务器地址:192.168.1.192
" |, `0 l7 ]* G0 Y" A) \: Z/ Z从数据库地址:192.168.1.193
/ S: E/ m' [4 i7 M$ r9 G( bps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb
$ b! x& R; t+ r/ S, V' ?1 h) s  e/ `4 y' W# |- c
流程:

# X" T+ b4 I0 L5 j1 k  C0 b主服务器0 |' \) J  I2 [) V" H, `3 l% L6 U) F
1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:
9 m# M2 k8 ]. J$ t$ o- }+ e5 _
server-id=1    #服务器 id
& N# L7 a* }9 F* V: _4 qlog-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径0 D6 A+ v- I+ U) {4 K
binlog-do-db=test1    #待同步的数据库7 l9 e! w" @$ h% l
binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写7 Z5 H8 D4 J3 i) G# G# {/ ?' V
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
: [, ~& I+ ]! C* e; l. @binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

1 ~7 R8 j4 D; p% z% L6 V  X/ Kexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
& _% b2 R2 @# V, j  d0 d
9 e& {$ J3 u. ^; Y, y2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;
! B; `3 h. H* ~. s9 u5 U
" ]8 W0 X; \& p3 }  e3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )
" T% u/ J3 b$ I; q' Q0 \2 [9 D2 W* G
. W" C$ c: z5 V! L, R+ A4:给要连接的从服务器设置权限: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即可)& M4 o( t! [% b! g' S( `! Q7 S
/ ~/ p: K; S" `' _2 l8 I
5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。1 T! x0 k) r* ~7 h
. ]1 C( Y, s( y- {/ w
6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。

3 {1 v+ S0 d* z* g
: `+ C% d2 |: ?% ?% X! L5 D其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
( n7 n9 s. [( ^' X
* i" D+ M# Y  {" K, {% K# i0 i1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:
# L+ h5 t; r7 [# e. w2 J
server-id=2    #服务器 id ,不能和主服务器一致0 T) ?1 G# j: \3 ?, x
replicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
& p! |) o- `# Z( h& ~# Jbinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写, z/ D( M) o0 C
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
( L0 \8 ~( i* Y: @: i2 Rbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
1 q$ j/ _9 S5 y7 a! e& }2 Q! Abinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写
* ^. y" p" g) J
expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)- c* Q5 z: z: g4 q& h
5 o6 o) m; `0 v/ e. d' Z" j
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
- u4 ?9 A% P9 C) k3 d7 X8 g; V6 x* }5 z; q: B/ F
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin9 d9 M5 w3 y) `0 C  q% i

% v4 t/ e  ?0 p6 T4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;* q, p- X7 |+ i+ m, u

' |  K8 J: k1 t" E# l( a9 M6 y5:修改对主数据库的连接的参数: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线程,然后再设置连接的参数;  O6 k5 `6 V# D& t, w/ n

: P/ T, a  E, ^2 p% P0 h* }6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes
$ [/ C  o, u/ B. j9 X$ ^1 P" DSlave_SQL_Running: Yes
# K0 q0 {2 v# X! _1 L
- U. o  H% [8 [# W- F
; ^  ^* J/ X* X2 q$ c
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-12 10:45 , Processed in 0.081755 second(s), 22 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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