MYSQL已有数据库有部分数据,做主从复制.
已经有数据库,做主从复制
服务器 | 备注 | 数据库 |
192.168.137.6 | Master | 有2个数据库,不同步mysql数据库 |
192.168.137.3 |
Slave | 没有数据库 |
Master操作
[mysqld] #############better########### log-bin = /www/wdlinux/mysql/data/binlog/mysql-bin.log server-id = 1 #Id号 expire-logs-days = 60 #binlog保留时间 max-binlog-size = 500M #binlog文件大小 server-id = 1 binlog-do-db = yhxt8xxx9cn #需要同步的数据库1 binlog-do-db = datafbdns #需要同步的数据库2 #binlog-ignore-db = mysql,performance_schema,wxmini #############end##############
多个数据库需要写多行binlog-do-db = xxx,不能这样写:binlog-do-db = db1,db2
#修改配置后,重启mysql数据库
/etc/init.d/mysql restart
#新建一个用户,用于slave同步master日志
GRANT REPLICATION SLAVE ON *.* To 'slave_user'@'192.168.137.%' IDENTIFIED BY 'slavepass';
flush privileges;
打开2个Xshell终端(s1,s2)
s1: FLUSH TABLES WITH READ LOCK; #锁定数据库,不让写入数据
s2: show master status; #获取binlog文件和位置.后面slave需要使用
s2: mysqldump -uroot -p'xxx' -B --master-data=1 --events datafbdns yhxtxxxcn >/root/datafbdns2.sql.gz #备份现有数据库.
s1: UNLOCK TABLES; #解除锁定
Slave操作
修改my.cnf
##############better slave config####### #log-bin=mysql-bin #binlog_format=mixed server-id = 2 #id必须和master不一样
#数据库操作
#导入数据库
mysql -uroot -p'xxxx#' </root/xxx.sql.gz
#配置master的相关信息.
CHANGE MASTER TO MASTER_HOST='192.168.137.6',MASTER_PORT=3306,MASTER_USER='slave_user' ,MASTER_PASSWORD='slavXXXX',MASTER_LOG_FILE='mysql-bin.000008',MASTER_LOG_POS=107;
#启动slave
slave start;
测试省略.