找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 15399|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi
* g( _) s! c, X- \- L: U* a$ R主服务器地址:192.168.1.192
* E9 {: }1 s: N: Z9 F0 g从数据库地址:192.168.1.193
$ I. R, k8 q2 F" ~2 Y2 {ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb: \  B2 r: D( |  x

  w' s# w! F& D' n! F流程:
* s2 f8 T) h& Y# i" h0 W! [
主服务器
0 x' R$ _  g4 `5 t" d7 `5 K8 J1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:
" c0 C3 V* _# p" O8 j* K3 X/ |
server-id=1    #服务器 id
# ?! ]& k: ~9 A& t- }+ ]  O8 `+ {& P2 U6 Alog-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径7 _( b3 d6 V& p
binlog-do-db=test1    #待同步的数据库
1 v9 y% ?. U9 k# `( Pbinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写. A& c8 a8 D0 [
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
1 ]4 ?' l: o' A5 l" x8 E% W$ j; Bbinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

; Y$ k* Q2 T1 }0 I- K* k; @3 fexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)4 {  y: B7 w* t. Q& Z' O
+ Q7 l$ {; g% i  h7 f9 `! ]8 k
2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;! I8 u4 G" \/ i8 N! k2 q

! B- p. A2 C  D# J% d9 Z3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )
% P5 Z* V* i9 z0 U1 z* k% m- N0 q0 G/ C
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即可)4 @/ i. F- ^3 P5 M1 J$ s! E

! o# H6 V: L* U+ D' k1 a" L5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。. U2 q8 q4 X. o2 {1 @

/ e7 O% j; `4 s3 T6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
5 U6 }# P2 H- i* ~

' a$ R. k8 i6 f1 P其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
" Z! W4 ]! F* p! y# [5 s( W: T4 U$ o3 i- m3 S% \- e$ }9 q
1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:
+ c7 O7 ?* l- k3 h. n) }: l1 q/ k0 S, r
server-id=2    #服务器 id ,不能和主服务器一致
2 ^: h5 X3 ]. [: {7 a% u( _replicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news/ k4 Y# v& p+ D+ J, \
binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写  L6 Y( i- Z. Z" u
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
6 A4 e6 U6 s( [0 p" G. W3 gbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
0 t: \0 C' ~- Ubinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

' H, i7 g5 A  r' ]9 oexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
- }( [) Q# J: ]% v8 P4 p
9 v+ C) y% B2 f+ e4 z0 I1 g2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;; r+ ?( U/ l, E3 E) T! ^. W3 S
0 p% J  X. H  U; l" M2 ]
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin3 J9 @: r7 x3 r6 O6 ~# S

9 l  y4 V2 t/ t! Z% J  [- Q4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;/ o; S3 y* [% c5 s1 t# _
& p* }+ U. l' p# D
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线程,然后再设置连接的参数;
4 J* M# k$ ^2 A/ E9 {' r# L" d4 o; l( K& w, e: N% F2 d9 U- Q
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes
& A- ]$ C5 v* U2 iSlave_SQL_Running: Yes

3 q, H! A1 u& O* q) ?/ ~7 \
& q9 b" \; y: y$ |8 U* [) |5 E! u- i# R
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-7 04:04 , Processed in 0.075627 second(s), 24 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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