Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2454488
  • 博文数量: 225
  • 博客积分: 11622
  • 博客等级: 上将
  • 技术积分: 7358
  • 用 户 组: 普通用户
  • 注册时间: 2006-04-18 10:05
个人简介

我们的生活是多么美好呀!!!!

文章存档

2013年(2)

2012年(9)

2011年(59)

2010年(8)

2009年(35)

2008年(112)

分类: Mysql/postgreSQL

2009-05-22 16:16:23

首先两台机器:

  a: 192.168.0.1

  b: 192.168.0.2

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

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

  在[mysqld]下添加以下内容

  server-id=1

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

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

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

  增加一个backup的用户

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

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

  因为要实现双向备份,所以a上还要加以下内容。 如果是单向,则不需要加。

  master-host=192.168.0.2

  master-user=backup

  master-password=backuppassword

  master-port=3306

  master-connect-retry=60

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

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

  打开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=不同步的数据库

  如果要双向同步则再加上以下内容

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

  binlog-do-db=要同步的数据库名称

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

  再增加一个帐号给a

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

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

  重起两边的服务器。 用show master status查看主服务器状态。 用 show slave status 查看从服务器状态。

  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;

阅读(985) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~