找回密码
 立即注册
查看: 10588|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi 4 N4 ], v/ i5 l6 O1 k3 l- ?
主服务器地址:192.168.1.192' ?2 r: G4 d! j/ I# \! w$ ]
从数据库地址:192.168.1.193+ x+ k: P0 E) j  X; `% O
ps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb
& ?4 F3 @, H# A  @3 a; e) w) x' V& g7 n8 W8 `6 l, Y
流程:
9 O7 `3 s3 E  e) \0 u
主服务器6 ^; z; W/ G9 C$ `: O
1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:

1 y( Q  j$ ]6 V( @( aserver-id=1    #服务器 id
9 t# ~% b, {) {$ u1 klog-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径
# Y6 I7 J3 m$ q8 v8 \8 S0 @- dbinlog-do-db=test1    #待同步的数据库- E, z" u  c8 S$ v& n4 u4 y
binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
% s- ]! {' b, S2 S& Ybinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写& Z# l  j2 U' S
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

; I! a4 H! ~3 s. d1 z, [expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
& s5 H8 i5 T$ W/ i! o( @- V/ t. T% n- C' i
2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;
0 Y9 b; L0 L$ f5 H
% t" _& k, _1 N" ?$ S3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )
. S5 X) Z& l1 J
  S5 h8 i: ?# a5 p0 f+ K4:给要连接的从服务器设置权限: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即可)
" G- _7 |; l1 I0 {% ]$ Q
; t) X' e. C( P: S' `2 u6 c6 C  z/ e5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。
0 U! G# D% \3 ~9 x* v5 P2 d& i+ ~7 E! D" L
6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。

# j: Z% d% X- F. ]) L9 U0 p% j7 d7 \2 b# `8 ~) z* C; h9 z+ }2 q& U
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
) u4 N0 r5 J$ a5 a2 h+ k; R. ^; S+ B7 p! t
1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:

+ @% v! g( g' `4 A0 Y) |  {- X; sserver-id=2    #服务器 id ,不能和主服务器一致, q# I' e8 m0 [$ u3 A
replicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
7 M5 M" y; C' j2 m) |- G1 Mbinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
, T; E  o9 t# b$ Vbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
+ l  I2 i: d5 ?# `  H4 ebinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写; ~) e/ |( A7 A: O( l
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

7 x$ A& x2 {6 {2 I2 v4 n0 fexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)& w1 P& F7 E6 F! k) O0 K. v
  m$ Q' u& T. v9 w: ?" y7 u4 p
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;. B9 f% r$ T0 `  m0 e) H; c4 X

& j  y* @1 \' W, R2 P3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin& n( c# }% }* [* z) }. x3 w3 G6 a

7 J8 {1 X6 O: l) `. G% y. d4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;
2 e# ^! e1 X3 p% ]
! `5 Q" n' ?8 Q; K" I+ ^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线程,然后再设置连接的参数;7 T% i" u" `9 p& }9 G  E
' [. i7 Z6 u* F8 l  @
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes  V. D. P1 Z6 m1 E
Slave_SQL_Running: Yes
" Q/ R: x1 V& [% P8 u4 D

0 M) S- i1 e: M3 t0 N" A5 l
6 R( C7 _7 E2 ~# j  \4 A2 t7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-29 08:38 , Processed in 0.097698 second(s), 23 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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