在主服务器 (master) 上启用二进制日志选择一个唯一的 server-id 创建具有复制权限的用户在从服务器 (slave) 上启用中继日志 (二进制日志可开启, 也可不开启) 选择一个唯一的 server-id 连接至主服务器, 并开始复制
2,MySQL 主从复制环境
两台机器一主一从.
主库(MySQL Master):[ip 为 192.168.46.129 port 为 3306]
从库(MySQL Slave ):[ip 为 192.168.95.130 port 为 3306]
3,MySQL 主配置文件(/etc/my.cnf 或者 / usr/my.cnf)
主库配置
1)设置 server-id 值并开启 binlog 参数
- [mysqld]
- log_bin = MySQL-bin
- server_id = 129 #主从两台服务器不一样
重启数据库(systemctl restart MySQL)
2) 建立同步账号
- MySQL> grant replication slave on *.* to 'rep'@'192.168.46.%' identified by '123456';
- MySQL> show grants for 'rep'@'192.168.46.%';
3)锁表设置只读
为后面备份准备, 注意生产环境要提前申请停机时间;
MySQL> flush tables with read lock;
提示: 如果超过设置时间不操作会自动解锁.
MySQL> show variables like '%timeout%';
测试锁表后是否可以创建数据库:
4)查看主库状态
查看主库状态, 即当前日志文件名和二进制日志偏移量
MySQL> show master status;
5)备份数据库数据
- mkdir /server/backup/
- # mysqldump -uroot -p -A -B |gzip> /server/backup/mysql_bak.$(date +%F).sql.gz
6)解锁
MySQL> unlock tables;
7)主库备份数据上传到从库
# scp /server/backup/mysql_bak.2015-11-18.sql.gz 192.168.95.130:/server/backup/
从库配置
1)设置 server-id 值并关闭 binlog 参数
- #log_bin = /data/MySQL/data/MySQL-bin
- server_id = 130
重启数据库:
2)还原从主库备份数据
- # cd /server/backup/
- # gzip -d mysql_bak.2015-11-18.sql.gz
- # MySQL -uroot -p <mysql_bak.2015-11-18.sql
检查还原:
# MySQL -uroot -p -e 'show databases;'
3)设定从主库同步
- MySQL> change master to
- MASTER_HOST='192.168.46.129', #主库的 IP 地址
- MASTER_PORT=3306,
- MASTER_USER='rep', #主库的授权用户
- MASTER_PASSWORD='123456', #用户密码
- MASTER_LOG_FILE='mysql-bin.000003', #主库的二进制日志
- MASTER_LOG_POS=329; #主库的状态信息
4)启动从库同步开关
MySQL> start slave;
检查状态:
MySQL> show slave status\G
主从状况监测主要参数
Slave_IO_Running: IO 线程是否打开 YES/No/NULL
Slave_SQL_Running: SQL 线程是否打开 YES/No/NULL
Seconds_Behind_Master: NULL #和主库比同步的延迟的秒数
两个 YES 代表成功了
4 常见的错误
1)要是克隆的机器需要修改从库的 uuid
- # VIM auto.cnf
- server-uuid=
2)关闭防火墙, selinux 等
3)
常见状态错误排除
show slave status; 报错: Error xxx doesn't exist
解决方法:
- stop slave;
- set global sql_slave_skip_counter = 1;
- start slave;
来源: http://www.jianshu.com/p/e5bad39872ed