MySQL的半同步复制_MySQL
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

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

本文讨论了使用MySQL的Alter Table语句修改表,包括添加/删除列,重命名表/列以及更改列数据类型。

文章讨论了为MySQL配置SSL/TLS加密,包括证书生成和验证。主要问题是使用自签名证书的安全含义。[角色计数:159]

文章讨论了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比较了它们对初学者和高级用户的功能和适合性。[159个字符]

本文讨论了使用Drop Table语句在MySQL中放下表,并强调了预防措施和风险。它强调,没有备份,该动作是不可逆转的,详细介绍了恢复方法和潜在的生产环境危害。

文章讨论了使用准备好的语句,输入验证和强密码策略确保针对SQL注入和蛮力攻击的MySQL。(159个字符)

本文讨论了在PostgreSQL,MySQL和MongoDB等各个数据库中的JSON列上创建索引,以增强查询性能。它解释了索引特定的JSON路径的语法和好处,并列出了支持的数据库系统。
