MySQL主从同步

先修改Master(192.168.1.197)的 my.cnf 配置



在 [mysqld] 中新增以下内容



log-bin = mysql-bin

log-bin-index = mysql-bin.index

server-id = 1

sync_binlog = 1

binlog_format = mixed



然后指定要做同步的数据库,并忽略掉不需要做同步的数据库



binlog-do-db = test_db

binlog-ignore-db = mysql

binlog-ignore-db = performance_schema

binlog-ignore-db = information_schema



在 [mysqldump] 中修改内容为

max_allowed_packet = 32M



注意:确保 max_allowed_packet 有比较大的值,比如 max_allowed_packet = 100M



重启 mysql 

service mysql restart



在Master上创建一个复制用户

CREATE USER repl_user;

GRANT REPLICATION SLAVE ON *.* TO repl_user IDENTIFIED BY '123456';



+ ---------------------------------------------------------- +



再修改 Slave(192.168.1.160)的配置,修改 my.cnf



在 [mysqld] 中新增以下内容



server-id = 2

log-bin = mysql-bin

relay-log-index = slave-relay-bin.index

relay-log = slave-relay-bin



sync_master_info = 1

sync_relay_log = 1

sync_relay_log_info = 1

# 以上三行话只使用于MySQL 5.5



输入 mysql -u root -p

进入mysql命令行,输入



CHANGE MASTER TO MASTER_HOST = '192.168.1.233', MASTER_USER = 'repl_user', MASTER_PORT = 3306, MASTER_PASSWORD = '123456';

CHANGE MASTER TO MASTER_CONNECT_RETRY = 30;

再输入 START SLAVE;



+ ----------------------- 如果发生错误无法启动 ------------------- +



进入Master 的数据库

输入 show master status\G

记录下当前使用的 log-bin文件,以及position (比如现在日志是 mysql-bin.000001 ,位置是 107)



然后进入Slave 的数据库

输入 stop slave;

change master to master_log_file='mysql-bin.000001', master_log_pos=107;

最后输入 start slave;



最后在服务器上执行

yum -y install ntpdate

ntpdate cn.pool.ntp.org

clock -w

把几台服务器的时间同步



+ ---------------------------- 一些可能用到的命令 ------------------------- +



执行锁表:

flush tables with read lock;

这一步的目的是使我们在制作主从的过程中,主库中不会有新的数据,否则会给我们的同步设置带来麻烦



主库执行解锁:

unlock tables;



reset master 命令删除了所有的二进制日志文件并清空了二进制日志索引文件。

reset slave 命令删除了Slave复制所用的所有文件,重新开始。



+ ----------------------- 其它参考文档(未验证)-------------------------- +



库业务不能停的情况下为从库制作镜像:

案例:

服务器1号:主

服务器2号:从

现在由于负载问题需要上架服务器3号同样为1号的从服务器。

但是1号库不能停,2号也不能停,主从同步进程也不能停(要求苛刻)

可以这样做:

在主:

mysqldump -uroot -pxxxx -h127.0.0.1 --databases db1 db2 db3 --master-data=1 > backup.sql

3号服务器
slave stop; 之后将backup.sql导入3号从服务器 slave start; 3号服务器会自动从导出的那一刻的节点更新。 因为
--master-data=1 这个参数在导出sql文件后会在最下方加上change语句。如果 --master-data=0 则不会带有。 非常的方便,但仅适合库不是太大的情况,该案例导出的库一共6G。

 

你可能感兴趣的:(Mysql主从)