找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 14711|回复: 1

mysql5.5主从同步备份设置

[复制链接]
发表于 2013-3-26 21:05:24 | 显示全部楼层 |阅读模式
环境:windows 7 ,mysql-5.5.18-win32.msi
2 n5 g4 N" m3 J/ C" Y" J主服务器地址:192.168.1.192; s' \2 Y/ y# `; D0 {  D7 L
从数据库地址:192.168.1.193
8 M1 h/ ?0 y4 H4 Ups.某些步骤可在phpmyadmin中设置!教程同样实用于linux注意路径即可,要同步的数据库:test1   同步帐号:slavetb/ V& N4 S2 l, k% F8 W( O; Z) V

. c) Y* {9 z( S流程:
' i* f2 j  N$ C
主服务器0 G) t% e* ?$ r" v+ U9 Q9 @4 e
1:在mysql下找到my.ini文件,在其[mysqld] 下添加主服务器端配置:
( p. ?) a$ F0 K, S1 a
server-id=1    #服务器 id
, K! v+ W8 q2 [; p9 A% Plog-bin=C:\Program Files\MySQL\MySQL Server 5.5\mysql-bin    #二进制文件存放路径! A  m/ X( m( P- n; X
binlog-do-db=test1    #待同步的数据库
% N. t2 G( n3 K; p$ ybinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
" d4 N$ S1 q3 r- o$ Tbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
9 G# K: S" {) K- H  Z$ Rbinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写
2 p- t+ n# D- b+ l7 l, S
expire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
* Z0 e0 i2 h+ [' ]! k+ y6 q; L6 R" e
* x: {- L+ {( J  U( g- V3 |: k2 B2:保存my.ini文件,重启数据库,然后会在C:\Program Files\MySQL\MySQL Server 5.5 下看到mysql-bin.index 文件和mysql-bin.000001文件;
- E" g! _. x( Y
: s% W* H* B5 B3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin输入用户名和密码:mysql -u用户名 -p密码 (    mysql -uroot -proot   )
6 L* M5 [- W9 i( Q- M# w- q5 b
3 ?- \: ?) I+ e4:给要连接的从服务器设置权限: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即可)1 ^. ?% {3 U' }! S% v

( w. f4 _" [0 ]% y5:输入命令 show master status\G       # 找到File 和 Position 的值记录下来在从服务器(Slave)配置同步关系会有用到的。/ l- @2 ?8 A  T, Z# Q2 E
( w9 g/ R& k% s
6:备份你要同步的数据库,然后导入从服务器,不要有数据修改添加操作,实在不行可暂时锁下表。
+ K1 l( M" S( ^5 U4 q) z- @. G8 f
# l! J8 m6 {( x. D
其实,主服务器是不需要设置太多信息的,只需要第1条中的前三行就足够了。下面配置从服务器:3 h8 R9 z! ?, |5 y" A

5 J. l2 G( ?" \; n% M0 v2 h6 K1:在mysql下找到my.ini文件,在其[mysqld] 下添加从服务器端配置:

) k/ Q( |, i0 s- Z% [$ n; yserver-id=2    #服务器 id ,不能和主服务器一致
& ?: P" c  B* Q- Y6 ?replicate-do-db=test1    #待同步的数据库,ps.如果只同步test1中的news表可改成这样:replicate-wild-do-table = test1.news
: u* ?( \3 {  G8 ybinlog-ignore-db=information_schema   #忽略不同步的数据库,这个可以不用写
, Y& O' f5 d* h3 O) ^: nbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
' p" s! \9 g% x" a3 M! c5 R. {; lbinlog-ignore-db=mysql    #忽略不同步的数据库,这个可以不用写
, @8 ]1 Y( o/ B+ ~$ {% Q& xbinlog-ignore-db=test    #忽略不同步的数据库,这个可以不用写

( N/ S& z$ Z7 v5 A/ [$ Bexpire_logs_days = 7     #超过7天自动删除日志文件可以防止同步日志文件过大(可选项)
# b1 ~" w; A& [0 q5 J+ t5 V1 O: |& A: ~4 ~7 o, i
2:保存my.ini文件,重启从数据库。ps.在mysql5.1以上版本中有个master设置这里已经取消无效了,如果添加了master设置,数据库就无法重启了;
$ \) u: m3 _& R2 C% P( Z2 j/ [9 j/ w' `; D& d8 Q! r
3:通过cmd进入mysql:cd C:\Program Files\MySQL\MySQL Server 5.5\bin
; ?' J! h1 P* \. i( ^4 g
# N/ W6 C. K: v) v. |& J! G% j# A4:从服务器上测试:mysql -uslavetb -p123456 -h192.168.1.192,查看能否连接主数据库成功,如果成功,则一定要退出来,之前我就是一直犯了一个错误,按照网上的步骤测试完毕之后就没有退出mysql,结果执行以下步骤时老是报错,其原因是一直设置的是主数据库;
$ @+ N& d& v0 A1 W# |2 z9 j* m  ^7 f6 v8 z/ C) j% ]4 D$ 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线程,然后再设置连接的参数;) _- j0 T! `$ p% p2 `6 x
+ l$ [3 F) n9 a- m9 a
6:设置完之后,执行 mysql> start slave; 开启slave线程;执行mysql> show slave status\G   (没有分号),查看Slave_IO_Running: Yes
3 m/ n: [4 Y$ s: k5 {& QSlave_SQL_Running: Yes
* O) z0 m+ m' C; y: T) A
7 m6 D4 `. H1 Z. s" y, a; `
0 C' G  _2 Z) t; l. f+ }+ G
7:完毕,在这个过程中我的测试结果一直是Slave_IO_Running:No;让我很是郁闷,一直没找到原因,错误代码如下,  后来找到了,其实原因很简单,当我测试连接主数据库之后我没有退出来,造成接下来的所有步骤都是对主数据库的操作; 其实主主同步也是相同的配置,只是相互为主机和从机的设置;
发表于 2013-4-1 01:05:39 | 显示全部楼层
讲解的很仔细,设置成功了!

点评

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-11-16 06:22 , Processed in 0.070203 second(s), 23 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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