您的位置:首页 > 数据库 > MySQL

Mysql 主从复制配置步骤

2011-01-20 16:40 846 查看
Mysql 主从复制配置步骤

说明:
推荐主服务器和从服务器使用相同的版本。在许多情况下,从新的主服务器向旧的从服务器复制将会失败。一般原则,版本较低的master可以和较高版本的slave一起可以正常工作,但不能反过来。

1.在master上建立有复制权限的账户
GRANT REPLICATION SL***E,RELOAD,SUPER ON *.* TO backup@60.*.*.* IDENTIFIED BY 'slavepass';
FLUSH PRIVILEGES ;


2.用mysqldump出master上的数据库并导入到slave上
master# mysqldump -uroot -p high>high.sql


3.在master 的my.cnf配置文件的replication部分添加:
server-id = 1
log_bin = /var/log/mysql/mysql-bin.log
binlog_do_db = high
binlog_ignore_db = mysql

重启mysql
# /etc/init.d/mysql restart
查看master的状态
mysql> show master status;


4.在slave 的my.cnf配置文件的replication部分添加:
server-id = 2
master-host = 60.*.*.*
master-user = backup
master-password = slavepass
master-port = 3300
replicate-do-db = high
replicate-ignore-db = mysql

重启mysql
# /etc/init.d/mysql restart
查看slave的状态
mysql> show slave status;

在slave上手动设置master:
查看master的信息:
mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 2244 | high | mysql |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)

停掉slave:
mysql> stop slave;

在slave上执行如下命令:
CHANGE MASTER TO MASTER_HOST='60.*.*.*', MASTER_PORT=3300,
MASTER_USER='backup', MASTER_PASSWORD='slavepass',MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=2244;

启动slave:
mysql> start slave;


5.在master的high库中创建、删除表,观察slave上是否也成功创建、删除表。


6.在slave上给high用户授权,以便在master出现问题时可以临时切到slave上。
GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP ON high.* TO 'high'@'60.*.*.%' IDENTIFIED BY 'high';
FLUSH PRIVILEGES;


7.问题
发现:Slave_IO_Running No
原因:没有在master对复制账号授权。按第一步操作即可解决。



8.主从服务器的复制状态查看命令:
SHOW PROCESSLIST;
SHOW MASTER STATUS;
show slave status;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: