• MySQL主从复制的原理及配置


    【http://www.jb51.net/article/50053.htm】
     
    MySQL 数据库的高可用性架构:
            集群,读写分离,主备。而后面两种都是通过复制来实现的。下面将简单介绍复制的原理及配置,以及一些常见的问题。
     
    【优点】
    1、 如果主服务器出现问题, 可以快速切换到从服务器提供的服务
    2、 可以在从服务器上执行查询操作, 降低主服务器的访问压力
    3、 可以在从服务器上执行备份, 以避免备份期间影响主服务器的服务
    注意一般只有更新不频繁的数据或者对实时性要求不高的数据可以通过从服务器查询, 实时性要求高的数据仍然需要从主数据库获得。
     

    【复制的原理】
      MySQL 复制基于主服务器在二进制日志中跟踪所有对数据库的更改(更新、删除等等)。

      每个从服务器从主服务器接收主服务器已经记录到其二进制日志的保存的更新,以便从服务器可以对其数据拷贝执行相同的更新。
      将主服务器的数据拷贝到从服务器的一个途径是使用LOAD DATA FROM MASTER语句。请注意LOAD DATA FROM MASTER目前只在所有表使用MyISAM存储引擎的主服务器上工作。并且,该语句将获得全局读锁定。

      MySQL 使用3个线程来执行复制功能,其中1个在主服务器上,另两个在从服务器上。当发出START SLAVE时,从服务器创建一个I/O线程,以连接主服务器并让它发送记录在其二进制日志中的语句。
      主服务器创建一个线程将二进制日志中的内容发送到从服务器。该线程可以识别为主服务器上SHOW PROCESSLIST的输出中的Binlog Dump线程
      从服务器I/O线程读取主服务器Binlog Dump线程发送的内容并将该数据拷贝到从服务器数据目录中的本地文件中,即中继日志
      第3个线程是SQL线程,是从服务器创建用于读取中继日志并执行日志中包含的更新。
      

      有多个从服务器的主服务器创建为每个当前连接的从服务器创建一个线程;每个从服务器有自己的I/O和SQL线程。


    【配置slave的扩展选项】

    master_host=db-master.mycompany.com
    master_port=3306
    master_user=rep
    master_password=freitag
    master_connect_retry=60 (若master宕机或者slave连接断开,slave会定期尝试连接到master上,重试的间隔由该选项来控制,默认值是60秒。)
    report_host=db-slave.mycompany.com
    slave_net_timeout=3600 (slave默认会在3600秒后,若还没收到来自master的数据,则会当作网络断开的情况来处理。)

     

    【MySQL高可用性大杀器之MHA】
    提到MySQL高可用性,很多人会想到MySQL Cluster,亦或者Heartbeat+DRBD,不过这些方案的复杂性常常让人望而却步,与之相对,利用MySQL复制实现高可用性则显得容易很多。http://blogread.cn/it/article/4677?f=wb

    【Mysql主从复制(master-slave)实际操作案例】
    http://www.jb51.net/article/51517.htm

  • 相关阅读:
    # 漏洞挖掘技巧清单 #
    CVE-2020-0796——SMBV3客户端/服务端远程代码执行漏洞(远程代码执行+权限提升)
    SSH公钥详细介绍及拓展
    滑动窗口(数据结构)
    反素数解析
    树状数组的基本操作
    Rochambeau POJ
    一般图最大匹配
    2020牛客暑期多校训练营(第一场)H Minimum-cost Flow
    A Bug's Life POJ
  • 原文地址:https://www.cnblogs.com/lsx1993/p/4626111.html
Copyright © 2020-2023  润新知