找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 15008|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi
. _% V# y; _& l; Z主服务器地址:192.168.1.192
) U+ ]+ y% A4 e6 c6 l+ l从数据库地址:192.168.1.193
$ Q. u  c8 [6 I8 {, cps.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb% D& ^' d; F/ ?/ r  q3 J
: _! L4 }* w% \; {
流程:

7 t3 s2 F6 ?! p8 @: M1 C! _1 ]主服务器
$ Y+ g) d; k0 t+ ~1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:

! ^( [7 ^: ~, k5 vserver-id=1    #服务器 id
; G- t" N% \" alog-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径- _& k+ F  Y" Z) j
binlog-do-db=test1    #待同步的数据库
( X: y% p: u- s% T' E3 gbinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写( @5 Z$ H0 A+ g7 T2 `
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
+ n( K% t+ p9 Z' Qbinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写
/ f' V2 f7 C' Z4 i4 |, S+ ~9 h
expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项). I( g$ x0 C* P! N
/ u1 S( L' m9 t9 |' d9 f7 l
2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;4 C* E7 [+ ^0 l; T

8 t  ?7 c  Y- e3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )' f' q3 i, N/ v" D$ ~; b
6 B% `  t% M' J9 _: x. _
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即可)% H. _: I9 U& A& A% ~; A% Z, b

5 \: Q- w9 x0 o5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。
; P, q* f- t- e6 o$ i; H2 V
. B* @/ M. t  ], X$ k; ~! z+ L6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。

0 N% I0 [8 _9 Q5 r0 q9 y
- |$ c' p* ~0 B8 l其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:
% U1 X; F5 n% q. R- W2 u# `
  r& r. g5 [* t- w9 [1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:

  O0 Y$ _' o, a. P' L3 Aserver-id=2    #服务器 id ,不能和主服务器一致
- N& m; l7 U$ w) b& U+ ^9 w. Breplicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news. b5 l8 r1 B) m, n0 h
binlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
2 z2 w8 S; r/ B1 `binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写2 p' u, _1 y* I8 z6 F
binlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写7 B  q( b8 {! c$ o
binlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

4 w) ^2 E( H  b. Q& W, }expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)  ]6 {- W1 ^) x. f' T
: J4 J4 z0 s, z- N+ f
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;; O0 J/ ]; [3 Y" b
' z$ y7 B* e3 a5 Y) J+ L9 w$ R: m
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin* B& e1 [& B( G9 G2 R$ x
$ f% q$ O" z. [3 {( P4 F+ D: `
4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;5 A" l0 s0 C+ y, D

* v' a8 b6 R- ]2 {; M5 L5:修改对主数据库的连接的参数: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线程,然后再设置连接的参数;
; f1 s6 e" e3 }: _/ A
$ I+ e* o' Y' M3 d6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes
4 v8 G: }( I. J% ESlave_SQL_Running: Yes
( I) m6 h1 o( k/ U9 w5 X

; c+ ?1 d! ^, f' K- B- s: w& I1 l& o1 [
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-17 04:53 , Processed in 0.050251 second(s), 23 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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