Mysql主从同步技术
核心原理架构图:
前置工作
准备两台服务器:
主库:Master 192.168.138.100
从库:Slave 192.168.138.101
【主库操作】
第一步:修改Mysq1数据库的配置文件/etc/my.cnf
[mysqld]
log-bin=mysql-bin #[必须]启用二进制日志
server-id=100 #[必须]服务器唯一ID
第二步:重启mysql服务
第三步:登录Mysql数据库,执行下面SQL
GRANT REPLICATION SLAVE ON *.* to 'xiaoming'@'%' identified by 'Root@123456';
注:上面SOL的作用是创建一个用户xiaoming,密码为Root@123456,并目给xiaoming用户授予REPLICATION SLAVE权限。常用于建立复制时所需要用到的用户权限,也就是slave必须被master授权具有该权限的用户,才能通过该用户复制。
第四步:登录Mysql数据库,执行下面SQL,记录下结果中File和Position的值
show master status;
执行完第四步后不要进行任何操作,否则会改变Postion的值!
【从库操作】
第一步:修改Mysq1数据库的配置文件/etc/my.cnf
[mysqld]
server-id=101 #[必须]服务器唯一ID
第二步:重启mysql服务
第三步:登录Mysql数据库,执行下面SQL
change master to master_host='192.168.138.100',master_user='xiaoming',master_password='Root@123456',master_log_
file='mysql-bin.000001',master_log_pos=439;
注:master_log_file='mysql-bin.000001',master_log_pos=439;
这两个值的内容要根据主库查询出来的来定(show master status;)
start slave;
第四步:登录Mysql数据库,查看slave表的状态
show slave status;
整理完之后,对主表进行操作一条语句
如果从表发生了与从表一样的变化,则代表配置成功!