找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 16408|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi
3 v4 p9 B& v: q1 n+ p' K主服务器地址:192.168.1.192
0 T" {* [* R' [3 W/ U从数据库地址:192.168.1.193
/ _- M& D8 u3 f# T2 {, Q4 tps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb
/ Q: e1 P* m8 g7 v  V% i  g
, c$ Z: D4 U3 J1 x3 t( k流程:
$ t6 L6 P; f2 t, C) |& D9 A
主服务器
$ W2 j- u: \5 ?' T1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:

* p; O  L3 D. O& d" {6 vserver-id=1    #服务器 id " `1 V/ F. H1 K& u' w7 q4 Y
log-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径
$ b% N' b  R- M$ {binlog-do-db=test1    #待同步的数据库& X( @4 Q) J* X# ]' z1 a) l
binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写4 n* y- R7 A8 Q" x4 G% {
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写9 Q6 o* _# ]2 h2 M7 l1 _  ]8 C4 P' b
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

% y' j1 O; s3 {% m4 Xexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
; ?; S: D& @* L0 u6 n- G* C
* @% {9 ], f0 H  c9 I2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;/ Y0 N% {$ T2 `! h4 D
5 C& `7 {/ S# `2 e
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )! Y8 q0 i, U' Y% F

5 I6 O8 g5 M$ T4:给要连接的从服务器设置权限: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即可)
, D: r; S9 h% j4 h& {: X
1 k9 R8 u+ p" E% x7 ^! b8 P5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。
5 U9 ?8 d$ o& f! @$ v9 F
; E# k  G/ n- e) f6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
# G8 z3 q" |4 n

. N: M) h% a, `" W  [其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:( _& r8 M% e  B. b

# L% E+ W9 q% E9 F; B1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:
" S. }& p9 {1 L
server-id=2    #服务器 id ,不能和主服务器一致! A8 }7 ]2 s$ b, R; X& z
replicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
/ X/ ^* S2 o$ B  S8 @9 I* L$ Hbinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
- w8 [/ W0 g7 K6 H/ C+ Ybinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写, r/ V* _, v* |3 h$ z  q" Y
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
% |  X9 O) d5 Z) @: gbinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

7 n. t/ D0 [: q( p; |+ v+ p9 t( t7 Z( }expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)3 n6 d5 r; A) L7 \+ E& Q: _9 Z/ A
# x1 T) s( s% Y# ~
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;+ e) H$ {1 F' A0 Y' _' q

0 m# N; I) ~: U3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin
- D8 r$ b; a: E, [& T' v4 x! O  |' {; k8 I' j
4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;9 G' u+ r* L  l! Q0 q1 e6 P. ~- f
5 A, c# h1 b2 |5 n" o
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线程,然后再设置连接的参数;8 i( d1 f8 T/ _5 p& q! X9 l
, j, S  H' n0 S8 x# l8 E3 v
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes/ i3 b, M& K8 u7 `. [4 G
Slave_SQL_Running: Yes

4 I; @, b( l: F( H! t  Y- _9 l# v2 ]0 D# }1 t8 g
) q4 O% K2 m' N+ b& j) k% h
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-5-16 20:20 , Processed in 0.112908 second(s), 25 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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