设为首页收藏本站
查看: 68|回复: 0

[PHP] MySQL的半同步复制_MySQL-mysql教程

[复制链接]

论坛元老

Rank: 6Rank: 6

积分
34274
主题
17031
UID
1347
M币
67
贡献
17176

  • 发表于 2017-5-12 16:11:00 | 显示全部楼层 |阅读模式
    1>半同步复制的出现:  
    默认情况下,复制是异步的,就是客户端提交事务给主库,主库将事务写入到存储引擎和binlog中后会立即返回给客户端告诉其事务执行成功。如果此时该事务还未来得及复制到从库上,如果主库在此时发生崩溃或者服务器宕机,会导致主从切换,此时客户端访问新选举的主库时,就会看不到刚提交的数据。
      
    2>半同步复制的原理:
      
    mysql5.5开始通过插件的方式支持半同步复制,主库执行完客户端提交的事务后不会立即返回给客户端,而是等待至少一个从库接收到该事务后才返回给客户端。
      
    半同步复制是全同步和异步同步的一个折中方案。与异步复制相比,半同步复制提高数据的安全性---可以保证至少两个地方存在该事务,同时也增加了一定的延迟(至少是一个tcp/ip往返的时间),最好在低延迟的网络中使用,比如局域网。


    3>半同步复制的安装配置
      
    须满足以下条件:
      
    MySQL5.5或者以上版本
      
    has_dynamic_loading系统变量设置为YES
      
    复制已经配置并且在运行。
      
    半同步复制是以插件形式实现的。所以讲semisync_master*文件复制到主库的plugins文件夹中,讲semisync_slave*文件复制到所有从库的plugins文件夹中。
      
    接下来分别在主库和从库上执行INSTALL PLUGIN命令加载插件。
    mysql> INSTALL PLUGIN rpl_semi_sync_master SONAME "semisync_master.so";
      
    从库上执行
    mysql> INSTALL PLUGIN rpl_semi_sync_slave SONAME "semisync_slave.so";
      
    查看插件的安装情况:
    mysql>SHOW PLUGINS;
      
    主从都开启半同步插件:
      
      主库上开启半同步插件:
      mysql>SET GLOBAL rpl_semi_sync_master_enabled = 1;
      mysql>SET GLOBAL rpl_semi_sync_master_timeout = N;//单位是毫秒
      
      在从库上开启半同步插件:
      mysql>SET GLOBAL rpl_semi_sync_slave_enabled = 1;
      
    rpl_semi_sync_master_timeout表示主库等待从库相应的超市时间,如果在时间内没有收到从库相应,复制切换到异步模式。
      
    停止slave IO 线程,然后重新开启该线程。以使slave IO 线程从新连接到主库,并以半同步方式在主库注册。
      
    在从库上执行以下命令重启slave IO线程:
    mysql>STOP SLAVE IO_THREAD;
    mysql>START SLAVE IO_THREAD;
      
    注意点:
      
    在mysql启动前将全局变量写入到配置文件中。以避免忘记设置使半同步不生效。
      
    主库配置文件
      [mysqld]
      rpl_semi_sync_master_enabled = 1
      rpl_semi_sync_master_timeout=10000 #10秒
      
    从库配置文件
      [mysqld]
      rpl_semi_sync_slave_enabled = 1
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    在我站开通SVIP可同时获得17个站点VIP资源 立即登录 立即注册
    快速回复 返回顶部 返回列表