找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 14233|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi / B3 g2 T4 `7 _% d- O0 E$ h7 U
主服务器地址:192.168.1.192
, M2 e, |, t  y) Q, x$ U从数据库地址:192.168.1.193
1 w; ^6 g: z4 Eps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb
! i! K9 J: B& J0 ]
" |6 c3 ~1 c5 W" P7 Y$ s- ~流程:
# Z1 x" T; j' D, ]: W. w- r6 H
主服务器
8 i7 k* y/ Y$ G0 s1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:
4 N9 _  l1 _5 v2 A0 ~% V
server-id=1    #服务器 id % A$ b6 ?1 k, n( U# n; v! k! _
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径
; }' [6 J" t0 Y  Mbinlog-do-db=test1    #待同步的数据库0 i0 s! V2 u6 G% e
binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写1 D* i; Y! x9 Z7 f9 q
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
- d0 o- x* s* H: O/ Gbinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

' F1 c  H/ }* q! E# _expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
& [6 x. q1 ^- G4 i5 S+ w2 C% W2 g  b6 u
2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;8 |6 L# [& V. i" I  u

% ]) W7 M  K: ~9 [- m3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )% h2 @; ?9 C9 i- e- `- j4 E3 a

7 ^( A4 N! Q+ B' i/ t& c4:给要连接的从服务器设置权限: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即可)
) K: e! k% L; \6 g* f! g+ W& d- |8 s$ H5 ?4 y
5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。( D) A5 M+ G7 c5 Y- l
9 ]$ ^( z  ?0 m5 |. o
6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。

% D+ Z- C4 ^/ H$ j6 r% |5 a7 @$ H/ T1 `! N2 V1 f
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:$ y- M. I! ~# T/ i: j& j8 H' e

+ y$ u* ], A4 U& H( \- T1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:

7 t2 u5 ?6 N0 r) J& {. I9 vserver-id=2    #服务器 id ,不能和主服务器一致
5 o1 m6 {+ o0 [- b+ m0 Ireplicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
2 X9 ]: G9 D9 e4 Mbinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写8 s8 S- u8 R; D( v6 U( a: m7 r8 K
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写! d6 D8 Q0 d# e/ ^3 U
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写3 Y; ?3 p+ J9 O" H
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

" {* M0 w9 H1 _expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
: u' a0 B5 p) h, Y! o6 A1 E3 R, w+ w7 ?! S
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
# D- a6 V& I& }5 R7 F
$ M3 D- E% }$ X3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin- L% f/ u9 V; j+ G: i& i0 [' s

" B2 G. k0 M' K! w4 S* ~1 B4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;
+ f6 h/ O6 P; Y* U3 H& ?( g' }1 p( @* `, c' E& p/ _
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线程,然后再设置连接的参数;
; z/ l: c+ j$ g' }  O- p4 }4 A: Y1 W' K2 J
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes
7 ?$ r- `( F5 S5 l3 F1 DSlave_SQL_Running: Yes

! y% F5 A6 v8 m( d
3 R- U* ^  k# [8 F9 _$ x& K( ~' M% Q$ O
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-9-14 07:09 , Processed in 0.100710 second(s), 24 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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