Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1481469
  • 博文数量: 463
  • 博客积分: 10540
  • 博客等级: 上将
  • 技术积分: 5450
  • 用 户 组: 普通用户
  • 注册时间: 2006-11-12 08:30
文章分类

全部博文(463)

文章存档

2014年(2)

2012年(14)

2011年(42)

2010年(18)

2009年(78)

2008年(35)

2007年(182)

2006年(92)

我的朋友

分类: Mysql/postgreSQL

2007-12-13 11:09:29

首先两台机器:

a: 192.168.0.1(主数据库)

b: 192.168.0.2(从数据库)

 

打开a机器的my.cnf/my.ini设置

首先要保证要同步的数据库内容完全一致

[mysqld]下添加以下内容

server-id=1# 编号,主辅库的唯一ID

log-bin=/var/db/mysql/master.log

binlog-do-db=要同步的数据库名称  //不写就同步全部。

#binlog-ignore-db = mysql //忽略的数据库

重起服务器,进入主库,用show master status查看主服务器状态。

 

b增加一个backup的用户

GRANT FILE,REPLICATION SLAVE,REPLICATION CLIENT,SUPER ON *.* TO backup@'192.168.0.2' IDENTIFIED by 'backuppassword';

这个权限表示,这个backup账号只能由从备份机192.168.0.2访问只能用来进行备份操作

 

打开b机器的my.cnf/my.ini文件

添加或修改以下内容

server-id=2

master-host=192.168.0.1

master-user=backup

master-password=backuppassword

master-port=3306

master-connect-retry=60

replicate-do-db=要同步的数据库

#replicate-ignore-db=不同步的数据库

重起服务器,进入辅库用 show slave status G ( G将表以分行形式、而不是表格形式输出)查看从服务器状态。

 

至此基于mysql的同步功能就做好了。

slave stop; 停止从服务器

slave start; 启动从服务器

master stop; 停止主服务器

master start; 启动主服务器

 

show processlist可以查看同步状态。

如果有什么错误打开mysql hostname.err 查看原因,再调用下面的修改命令:

CHANGE MASTER TO

MASTER_HOST='master_host_name',

MASTER_USER='master_user_name',

MASTER_PASSWORD='master_pass',

MASTER_LOG_FILE='recorded_log_file_name',

MASTER_LOG_POS=recorded_log_position;

然后再重起slave;

 

注: 此方法适用于主库 log 完整的情况,如果不完整,需要将主库关闭->打包->传到辅库->解包。即需要选择一个时间点,手工同步两个库后,保证主库的log完整。

阅读(1632) | 评论(0) | 转发(0) |
0

上一篇:LVS大全

下一篇:MYSQL的实时同步

给主人留下些什么吧!~~