MySQL的半同步复制_MySQL

php中文网
发布: 2016-05-30 17:11:12
原创
956人浏览过

1>半同步复制的出现:

 

默认情况下,复制是异步的,就是客户端提交事务给主库,主库将事务写入到存储引擎和binlog中后会立即返回给客户端告诉其事务执行成功。如果此时该事务还未来得及复制到从库上,如果主库在此时发生崩溃或者服务器宕机,会导致主从切换,此时客户端访问新选举的主库时,就会看不到刚提交的数据。

 

2>半同步复制的原理:

 

mysql5.5开始通过插件的方式支持半同步复制,主库执行完客户端提交的事务后不会立即返回给客户端,而是等待至少一个从库接收到该事务后才返回给客户端。

 

半同步复制是全同步和异步同步的一个折中方案。与异步复制相比,半同步复制提高数据的安全性---可以保证至少两个地方存在该事务,同时也增加了一定的延迟(至少是一个tcp/ip往返的时间),最好在低延迟的网络中使用,比如局域网。

MySQL的半同步复制_MySQL

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;

 

主从都开启半同步插件:

Modoer多功能点评系统2.5 精华版 Build 20110710 UTF8
Modoer多功能点评系统2.5 精华版 Build 20110710 UTF8

Modoer 是一款以本地分享,多功能的点评网站管理系统。采用 PHP+MYSQL 开发设计,开放全部源代码。因具有非凡的访问速度和卓越的负载能力而深受国内外朋友的喜爱,不局限于商铺类点评,真正实现了多类型的点评,可以让您的网站点评任何事与物,同时增加产品模块,也更好的网站产品在网站上展示。Modoer点评系统 2.5 Build 20110710更新列表1.同步 旗舰版系统框架2.增加 限制图片

Modoer多功能点评系统2.5 精华版 Build 20110710 UTF8 2
查看详情 Modoer多功能点评系统2.5 精华版 Build 20110710 UTF8

 

   主库上开启半同步插件:

   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

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号