17.1.2.1 Advantages and Disadvantages of Statement-Based and Row-Based Replication
17.1.2.1 Advantages and Disadvantages of Statement-Based and Row-Based Replication
基于语句和基于行复制的优点和缺点:
每种 binary logging 格式有优势和缺点,对于很多用户,
混合的复制格式 应该提供最好的数据完整性和性能的最佳组合。
如果,但是, 你需要利用基于语句的功能或者基于行的功能 当执行某些任务,
你可以使用信息在这个章节, 它提供了一个相对的优点和缺点,以确定哪一个适合你
基于语句的复制的优点:
1. 提供的技术 在MySQL 3.23z种已经出现
2.较少的数据被写入到log files,当更新或者删除影响很多行的时候,这个结果是更少的存储空间需要用于log files.
这也意味着做备份和恢复备份可以更快的完成
Log files 包含所有的语句,做出的任何改变,因此可以用于审计数据库
Disadvantages of statement-based replication 基于语句的复制的缺点:
语句对于SBR是不安全的, 不是所有的语句修改数据(比如 INSERT DELETE, UPDATE, and REPLACE statements) 可以被复制
使用基于语句的复制。 任何非确定的行为是很难复制当使用基于语句的复制。
比如这样的DML 语句如下:
一个语句依赖 一个UDF或者存储过程是不确定的,因为 这样一个UDF返回的值 或者存储过程或者取决于因数意外的其他因数
(基于行的复制,然而, 简单的复制UDF返回的值或者存储过程, 因此它影响表的记录和数据是master和slave相同的
DELETE 和UPDATE 语句是使用一个LIMIT 子句没有一个ORDER BY 是不确定的
语句使用任何的下面的函数不能被正确的复制 使用基于语句的复制:
LOAD_FILE()
UUID(), UUID_SHORT()
USER()
FOUND_ROWS()
SYSDATE() (unless both the master and the slave are started with the --sysdate-is-now option)
GET_LOCK()
IS_FREE_LOCK()
IS_USED_LOCK()
MASTER_POS_WAIT()
RAND()
RELEASE_LOCK()
SLEEP()
VERSION()
然而, 所有其他的函数是可以正确复制的 使用基于语句的复制,包含NOW() 等等
语句不能被正确复制使用基于语句的复制是被记录一个警告如下:
[Warning] Statement is not safe to log in statement format.
一个类似的警告,也会向客户端发出,客户端可以通过使用SHOW WARINGS
1.INSERT ... SELECT 需要大量的row-level locks 相比基于行的复制
2.UPDATE 语句 需要一个表扫描(因为没有索引是用于WHERE 子句)必须锁住大量的行 相比基于行的复制
3.对于 InnoDB: 一个INSERT 语句使用 AUTO_INCREMENT 锁住其他不冲突的插入语句
4.对于复杂的语句,语句 必须评估和执行在slave上 在记录被更新或者插入。
在基于行的复制, slave 只修改影响的行,不会执行整个语句
5. 如果有一个错误在出现在slave上评估的时候,特别是当执行复杂的语句,
基于语句复制可能会缓慢增加错误的范围 更具受影响的行。
存储函数执行相同的NOW() 值当调用语句,然而,这不是正确的存储过程。
Advantages of row-based replication 基于行的复制:
所有的变化都可以被复制,这是最安全的复制形势。
注意:
语句在mysql 数据库中的更新,比如GRANT,REVOKE 和操作触发器,存储过程,
和视图 是都会复制到slave 使用基于语句的复制。
对于语句比如 CREATE TABLE ... SELECT, 一个CREATE 语句是生成从表定义和复制使用基于语句的格式,
当记录插入是被复制使用基于行的
这个技术是和很多其他的数据管理系统类似,对其他系统转移到MySQL
更少的锁是被需要在master上, 从而实现高并发 对面一下类的语句:
INSERT ... SELECT
INSERT statements with AUTO_INCREMENT
UPDATE or DELETE statements with WHERE clauses that do not use keys or do not change most of the examined rows.
UPDATE or DELETE statements 在WHERE 子句不使用keys或者不改变检验的行
需要更少的锁 在Slave上对于 INSERT, UPDATE, or DELETE statement.
17.1.2.1 Advantages and Disadvantages of Statement-Based and Row-Based Replication的更多相关文章
- 17.1.2.1 Advantages and Disadvantages of Statement-Based and Row-Based Replication 基于语句和行的复制的优势和劣势
17.1.2.1 Advantages and Disadvantages of Statement-Based and Row-Based Replication 基于语句和行的复制的优势和劣势 每 ...
- Vue 单页面应用 SEO SPA single page application advantages and disadvantages
处理 Vue 单页面应用 SEO 的另一种思路 - muwoo - 博客园 https://www.cnblogs.com/tiedaweishao/p/7493971.html SPA网站SEO完美 ...
- 17.1.2 Replication Formats
17.1.2 Replication Formats 复制格式 17.1.2.1 Advantages and Disadvantages of Statement-Based and Row-Bas ...
- 17.1.2?Replication Formats 复制格式:
17.1.2?Replication Formats 复制格式: 17.1.2.1 Advantages and Disadvantages of Statement-Based and Row-Ba ...
- mha安装使用手册
mha安装使用手册 注:目前mha最新的版本代码已经不放到google code网站了,而是放在github上,最新的版本为0.57,github链接如下: mha manager:https://g ...
- [MySQL Reference Manual]17 Group Replication
17 Group Replication 17 Group Replication 17.1 Group Replication后台 17.1.1 Replication技术 17.1.1.1 主从复 ...
- sentence patterns
第四部分 推理题 1.世界上每个角落的每个人都有立场,都有背景,都有推理性,能推理出一个人语言的真意,才成就了真正的推理能力: 2.换言之,如果你能通过一个人的说话推理出其身份职业,你的推理能 ...
- Searching External Data in SharePoint 2010 Using Business Connectivity Services
from:http://blogs.msdn.com/b/ericwhite/archive/2010/04/28/searching-external-data-in-sharepoint-2010 ...
- Data manipulation primitives in R and Python
Data manipulation primitives in R and Python Both R and Python are incredibly good tools to manipula ...
随机推荐
- C++_基础_运算符重载
内容: (1)输入输出运算符重载 (2)友元类和友元函数 (3)双目运算符重载 (4)单目运算符重载 (5)不能被重载的运算符 (6)只能定义为成员形式的运算符 1.输入输出运算符重载如: int n ...
- TCP/IP的网际层协议——ARP
MAC地址对于每一台设备是全球唯一的,该地址被烧录在网卡的硬件电路上.MAC地址由12位十六进制数表示,其中前6位标识网卡的制造厂商,后6位是网卡的序列号.在以太网中,一个主机要和另一个主机进行通信, ...
- hadoop搭建杂记:Linux下不同linux主机之间文件copy的scp命令
不同的Linux之间copy文件常用有3种方法: 不同的Linux之间copy文件常用有3种方法: ①ftp 就是其中一台Linux安装ftp Server,这样可以另外一台使用ftp的程序来进行文件 ...
- 本地搭建php环境
AppServ 是 PHP 网页架站工具组合包,所包含的软件有:Apache[.Apache Monitor.PHP.MySQL.phpMyAdmin等,如果您的本地机器没有安装过php.mysql等 ...
- 《Pointers On C》读书笔记(第三章 数据)
1.在C语言中,仅有4种基本数据类型:整型.浮点型.指针和聚合类型(如数组和结构等). 整型家族包括字符.短整型.整型和长整型,它们都分为有符号和无符号两种. 标准规定整型值相互之间大小的规则:长整型 ...
- JS 节流阀
JS 节流阀 参考 https://github.com/hahnzhu/read-code-per-day/issues/5 节流阀 节流阀的基本原理 事件函数的执行都记下当前时间, 只有当前时间与 ...
- .net mvc笔记3_Understanding Razor Syntax
Understanding Razor Syntax MVC3新视图引擎的名字叫做Razor.ASP.NET视图引擎处理web页面,寻找包含在服务器端指令的特殊元素.正如我们前面已经提到的,标准的AS ...
- 自定义TWebBrowser浏览器控制遇到的一些问题
最近工作需要,要将TWebBrowser样式改头换面,包括菜单,滚动条等,都要换掉. 由于滚动条已经屏蔽掉,所以关于页面滚动等,全部都需要自己写代码来模拟了.模拟的过程中发现获得页面的客户区大小Cli ...
- Linux 电子书共享下载--大家一起学习
文件名 大小 时间 到期时间 操作 鸟哥私房菜(全集).pdf 36.57 MB 2 小时前 免费永久 练成Linux高手.chm 3.76 MB 2 小时前 免费永久 ...
- cocos2d-x Touch 事件应用的一个例子
1效果图: 这个是<Cocos2d-X by Example Beginner's Guide>上的第一个例子,我稍微重构了下代码.是一个简单的IPad上的双人游戏,把球射入对方的球门就得 ...