mysql主从复制(按步骤就可以实现了)

MYSQL的主从复制

当单台MYSQL服务器无法满足当前网站流量时的优化方案。需要搭建mysql集群技术。

  • 功能:

当向主服务器插入|修改|删除数据时,数据会自动同步到从服务器。

注意:主从复制是单向的,只能主 -> 从

分为两种类型:发射型(一主多从):一般使用在:备份、读写分离。

mysql主从复制(按步骤就可以实现了)

环形(多主多从):一般使用:当主服务器压力大时、跨地区的网站实现数据同步

mysql主从复制(按步骤就可以实现了)

在环形结构中,如果同时向三台服务器的同一表插入记录会出现“ID冲突的问题”。

解决办法:让三台服务器生成不同的ID;

第一台:1,4,7...

第二台:2,5,8..

第三台:3,6,9...

这个可以MYSQL的配置文件中设置:

 

mysql主从复制(按步骤就可以实现了)

  • 主从的原理(利用了bin日志)

Mysql中有一种日志叫做bin日志(二进制日志)。这个日志会记录下所有修改了数据库的SQL语句(insert,update,delete,ALTER TABLE,grant等等)。主从复制的原理其实就是把主服务器上的BIN日志复制到从服务器上执行一遍,这样从服务器上的数据就和主服务器上的数据相同了。

扩展:mysql中的日志:

  1. 查询日志
  2. 错误日志
  3. Bin日志
  4. 慢日志:你可以设置一个时间阀值,如0.5秒,那么将来所以执行时间超过这个值的SQL语句就会被记录下来。这样我们就可以把慢的SQL语句记录下来,专门进行优化。

       用途:可以快速定位到网站中比较拖网站的SQL,然后可以优化:建索引,缓存这个SQL的结果。

 

  • 实际的配置

把windows系统的MYSQL做为主服务器,LINUX下的做为从服务器。

主服务器:

1. 开启bin日志

修改mysql的配置文件:my.ini添加:

mysql主从复制(按步骤就可以实现了)

2,为服务器指定一个server-id(主从服务器的ID值不能重复)

mysql主从复制(按步骤就可以实现了)

mysql主从复制(按步骤就可以实现了)

mysql主从复制(按步骤就可以实现了)