1.创建一个数据库用于测试同步;
mysql> create database dragon;
Query OK, 1 row affected (0.04 sec)
mysql> use dragon
Database changed
mysql> create table user(id int(5),name char(20));
Query OK, 0 rows affected (0.17 sec)
mysql> quit
2.修改主库my.cnf主要设置个不一样的ID,以及同步的数据库的名字,我一般用vim 来完成,vim /etc/my.cnf 在[mysqld]中加入内容如下
server-id=1
log-bin=binlog
binlog-do-db=dragon #指明同步那些数据库
replicate-ignore-db=mysql #指明不同步那些数据库
replicate-ignore-db=information_schema
port=3306
重启服务使得配置文件生效
[root@localhost ~]# service mysqld restart
Shutting down MySQL. [确定]
Starting MySQL.. [确定]
[root@localhost ~]# mysql -uroot -p123
3.登录主库赋予从库权限账号,允许用户在主库上读取日志(用户名: admin密码:123456)
[root@localhost ~]# mysql -uroot -p123
mysql> grant replication slave on *.* to 'admin'@'10.10.10.2' identified by '123456';
Query OK, 0 rows affected (0.01 sec)
在slave上测试账号是否能够被登陆:
[root@localhost ~]# mysql -uadmin -p123456 -h 10.10.10.1 -S/tmp/mysql.sock
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.5.33-log Source distribution
Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>
4.slave机器获取mastre快照。有两种方法:一种是进入/var/lib/mysql/用tar方法备份,另一种用mysqldump.
[root@localhost mysql]# cd /usr/local/mysql/data/
[root@localhost data]# tar czvf dragon.tar.gz dragon/
dragon/
dragon/db.opt
dragon/user.frm
[root@localhost data]# scp dragon.tar.gz 10.10.10.2:/usr/local/mysql/data
The authenticity of host '10.10.10.2 (10.10.10.2)' can't be established.
RSA key fingerprint is 01:77:02:41:8b:f3:86:3e:e9:58:b3:f2:91:34:91:90.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '10.10.10.2' (RSA) to the list of known hosts.
root@10.10.10.2's password:
dragon.tar.gz 100% 416 0.4KB/s 00:00
[root@localhost data]# tar zxf dragon.tar.gz
[root@localhost data]# service mysqld restart
5.在master1上查看dragon数据文件的信息(记录file、position,从库设置将会用到),并且锁住表;
mysql> flush tables with read lock;
Query OK, 0 rows affected (0.01 sec)
mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000024 | 563 | dragon | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
mysql> unlock tables;
6.修改slave2的配置文件vim /etc/my.cnf,把server_id改为2或者添加server_id=2,总之server_id是一个与master的server_id不同数值即可,如果server_id与master相同会出现1593这个错误,可以进入数据库通过" show variables like "server_id""来查看servver_id是否被更改. 进入slave的数据库进行下一步同步配置。
mysql> slave stop;
Query OK, 0 rows affected (0.00 sec)
mysql>change master to master_host='10.10.10.1',master_user='admin',master_password='123456',master_log_file='mysql-bin.000024 ',master_log_pos=563;
mysql> slave start;
Query OK, 0 rows affected (0.00 sec)
重启一下数据库:service mysqld restart;再进入数据库查看同步是否成功,slave_io_running和slave_sql_running均为YES。
mysql>show slave status\G;
…
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
在master1上创建一个表,再到slave上查看表有没有被同步到。
mysql> create table dragonttest(id int(4),name char(10));
Query OK, 0 rows affected (0.18 sec)
mysql>
mysql> show tables;
+------------------+
| Tables_in_dragon |
+------------------+
| dragonttest |
| user |
+------------------+
2 rows in set (0.00 sec)
配置主主备份:
这里才是主主复制的开始,其实方法很简单,我们之前可以实现主从复制也就是说,再把从做为主,主再做为从,就实现主主复制了,我是在主从复制完成后在此基础上去完成主主复制的。
1、编辑之前的从服务器,也就是现在的master2
vim /etc/my.cnf
加入如下内容:
binlog-do-db=dragon
replicate-ignore-db=test
replicate-ignore-db=mysql
replicate-ignore-db=information_schema
port=3306
2.重启服务
service mysqld restart
3、登录master2(master2 Ip地址为10.10.10.2)数据库赋予master数据库权限账号,允许用户在master主库(ip 为10.10.10.1)上读取日志(用户名: admin密码:123456)
mysql -uroot -p123
grant replication slave on *.* to 'admin'@'10.10.10.1'identified by '123456';
为验证账号我们可以在master1的机器上用命令作如下测试
mysql -u admin -p -h 10.10.10.2 -S/tmp/mysql.sock
4、master2上登录数据库记录file 和position
mysql> show master status;
+---------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+---------------+----------+--------------+------------------+
| binlog.000004 | 106 | dragon | |
+---------------+----------+--------------+------------------+
1 row in set (0.00 sec)
5、在master上登录数据库做如下配置
mysql>stop slave;
mysql>CHANGE MASTER TO MASTER_HOST='10.10.10.2',MASTER_USER='admin',MASTER_PASSWORD='123456',MASTER_PORT=3306,MASTER_LOG_FILE='binlog.000004 ',MASTER_LOG_POS=106; (请注意CHANGE 到pos=106为一行命令)
mysql>start slave;
mysql>show slave status\G;
…
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
…
看到上两个进程为数据库与另一边的master 已经建立连接