环境:
主服务器上的MySQL数据库版本同为5.5.29
主机IP:192.168.0.1
从机IP:192.168.0.2
一. MySQL主服务器配置(0.1机器)
1.编辑配置文件/data/dbroot/my.cnf
# 确保有如下行
server-id = 1
log-bin=mysql-bin
binlog-do-db = home #需要备份的数据库名,如果备份多个数据库,重复设置这个选项即可
binlog-do-db = uc
binlog-do-db = edm
binlog-ignore-db=mysql #不需要备份的数据库名,如果备份多个数据库,重复设置这个选项即可
log-slave-updates #这个参数一定要加上,否则不会给更新的记录些到二进制文件里
slave-skip-errors #是跳过错误,继续执行复制操作
2.建立用户
先进入mysql
mysql -u root -p pwd
建立用户
grant replication slave on *.* to ‘用户名’@'主机’ identified by ‘密码’;
mysql> grant replication slave on *.* to [email protected] identified by ‘123456′;
# 可在Slave上做连接测试: mysql -h -u test -p (在从服务器上0.2上测试这个)
3.锁主库表(为了记录file和position保持一致,也可以不锁表)
mysql> FLUSH TABLES WITH READ LOCK;
4.显示主库信息
记录File和Position,从库设置将会用到(0.2那台设置用到这个。)
=====================
mysql> SHOW MASTER STATUS;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_do_db | Binlog_ignore_db |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 106 | | |
+------------------+----------+--------------+------------------+
ps:如果这里没有显示结果,需要重启一下mysql,再查看,
5.另开一个终端,打包主库
cd /data/dbroot/ #mysql库目录
tar zcvf home.tar.gz home
============================
二.MySQL从服务器配置(0.2机器)
1、传输拿到主库数据包、解包
mysql根目录 /usr/local/mysql/data
scp [email protected]:/data/dbroot/home.tar.gz /usr/local/mysql/data
tar zxvf home.tar.gz
2.编辑 /etc/my.cnf (如果没有就创建一个)
server-id=2
log-bin=mysql-bin
master-host=192.168.0.1 <主服务器地址>
master-user=test <主服务器上创建的用户名>
master-password=123456
master-port=3306
replicate-do-db=home #需要备份的数据库名
replicate-ignore-db=mysql #忽略的数据库
master-connect-retry=60 #如果从服务器发现主服务器断掉,重新连接的时间差(秒)
log-slave-updates #这个参数一定要加上,否则不会给更新的记录些到二进制文件里
slave-skip-errors #是跳过错误,继续执行复制操作
3、验证连接MASTER
# mysql -h 192.168.0.1 -u test -p 123456
mysql> show grants for [email protected];
验证完记得quit;
4、在SLAVE上设置同步
#mysql -u root -p
设置连接MASTER MASTER_LOG_FILE为主库的File,MASTER_LOG_POS为主库的Position (就是主服务器执行SHOW MASTER STATUS;得的结果)
============================
mysql> slave stop;
mysql> CHANGE MASTER TO MASTER_HOST='192.168.0.1',MASTER_USER='test',MASTER_PASSWORD='123456',MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=106;
5、启动SLAVE服务
mysql> slave start;
6、查看SLAVE状态
mysql> SHOW SLAVE STATUS\G;
其中 Slave_IO_Running 和 Slave_SQL_Running 两列的值都为 "Yes",表明 Slave 的 I/O 和 SQL 线程都在正常运行。
mysql> show slave status\G;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.0.1
Master_User: test
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000001
Read_Master_Log_Pos: 85783
Relay_Log_Pos: 30477
Relay_Master_Log_File: mysql-bin.000001
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB:
三、 解锁主库表(主服务器的0.1机器)
mysql> UNLOCK TABLES;
到此主从库搭建成功。可以在主库上插入数据测试同步是否正常。
【转】http://blog.sina.com.cn/s/blog_777af16d0101lego.html
http://my.oschina.net/u/1169079/blog/228957
http://www.jb51.net/article/27221.htm
http://my.oschina.net/innovation/blog/283024