您现在的位置:新闻首页>资本 > MySQL中使用binlog时binlog格式的选择
MySQL中使用binlog时binlog格式的选择
mysql教程栏目介绍使用binlog时binlog格式的选择。
一、binlog的三种模式1.statement level模式
每一条会修改数据的sql都会记录到master的bin-log中。slave在复制的时候sql进程会解析成和原来master端执行过的相同的sql来再次执行。 优点:statement level下的优点,首先就是解决了row level下的缺点,不需要记录每一行数据的变化,减少bin-log日志量,节约io,提高性能。因为他只需要记录在master上所执行的语句的细节,以及执行语句时候的上下文的信息。 缺点:由于它是记录的执行语句,所以为了让这些语句在slave端也能正确执行,那么他还必须记录每条语句在执行的时候的一些相关信息,也就是上下文信息,以保证所有语句在slave端被执行的时候能够得到和在master端执行时候相同的结果。另外就是,由于mysql现在发展比较快,很多的新功能加入,使mysql的复制遇到了不小的挑战,自然复制的时候涉及到越复杂的内容,bug也就越容易出现。在statement level下,目前已经发现的就有不少情况会造成mysql的复制问题,主要是修改数据的时候使用了某些特定的函数或者功能的时候会出现,比如sleep()在有些版本就不能正确复制。
2.rowlevel模式
日志中会记录成每一行数据被修改的形式,然后在slave端再对相同的数据进行修改 优点:bin-log中可以不记录执行的sql语句的上下文相关的信息,仅仅只需要记录那一条记录被修改了,修改成什么样了。所以row level的日志的内容会非常清楚的记录下每一行数据修改的细节。而且不会出现某些特定情况下的存储过程,或function,以及trigger的调用和触发无法被正确复制的问题。 缺点:row level下,所有的执行的语句当记录到日志中的时候,都将以每行记录的修改记录,这样可能会产生大量的日志内容,比如有这样一条update语句:update product set owner_member_id='d' where owner_member_id='a',执行之后,日志中记录的不是这条update语句所对应的事件(mysql是以事件的形式来记录bin-log日志),而是这条语句所更新的每一条记录的变化情况,这样就记录成很多条记录被更新的很多事件。自然,bin-log日志的量会很大。
3.mixed模式
实际上就是前两种模式的结合,在mixed模式下,mysql会根据执行的每一条具体的sql语句来区分对待记录的日志形式,也就是在statement和row之间选一种。新版本中的statement level还是和以前一样,仅仅记录执行的语句。而新版本的mysql中对row level模式被做了优化,并不是所有的修改都会以row level来记录,像遇到表结构变更的时候就会以statement模式来记录,如果sql语句确实就是update或者delete 等修改数据的语句,那么还是会记录所有行的变更。
二、我们使用binlog时应该选择什么格式呢
通过上面的介绍我们知道了binlog_format为STATEMENT在一些场景下能够节省IO、加快同步速度,但是对于InnoDB这种事务引擎,在READ-COMMITTED、READ-UNCOMMITTED隔离级别或者参数innodb_locks_unsafe_for_binlog为ON时,禁止binlog_format=statement下的写入,同时对于binlog_format=mixed这种对于非事务引擎、其他隔离级别默认写statement格式的模式也只会记录row格式。
> select @@tx_isolation; +----------------+ @@tx_isolation +----------------+ READ-COMMITTED +----------------+ > create table t(c1 int) engine=innodb; > set binlog_format=statement; > insert into t values(1); ERROR 1665 (HY000): Cannot execute statement: impossible to write to binary log since BINLOG_FORMAT = STATEMENT and at least one table uses a storage engine limited to row-based logging. InnoDB is limited to row-logging when transaction isolation level is READ COMMITTED or READ UNCOMMITTED. > set binlog_format='mixed'; > show binlog events in 'mysql-bin.000004'\G *************************** 3. row *************************** Log_name: mysql-bin.000002 Pos: 287 Event_type: Gtid Server_id: 3258621899 End_log_pos: 335 Info: SET @@SESSION.GTID_NEXT= 'ed0eab2f-dfb0-11e7-8ad8-a0d3c1f20ae4:9375' *************************** 4. row *************************** Log_name: mysql-bin.000002 Pos: 335 Event_type: Query Server_id: 3258621899 End_log_pos: 407 Info: BEGIN *************************** 5. row *************************** Log_name: mysql-bin.000002 Pos: 407 Event_type: Table_map Server_id: 3258621899 End_log_pos: 452 Info: table_id: 124 (test.t) *************************** 6. row *************************** Log_name: mysql-bin.000002 Pos: 452 Event_type: Write_rows_v1 Server_id: 3258621899 End_log_pos: 498 Info: table_id: 124 flags: STMT_END_F *************************** 7. row *************************** Log_name: mysql-bin.000002 Pos: 498 Event_type: Xid Server_id: 3258621899 End_log_pos: 529 Info: COMMIT /* xid=18422 */复制代码
为什么READ-COMMITTED(RC)、READ-UNCOMMITTED下无法使用statement格式binlog?这是因为语句在事务中执行时,能够看到其他事务提交或者正在写入的数据。事务提交后binlog写入,然后在从库回放,就会看到的数据会与主库写入时候不对应。 例如: 有表:
+------+------+ a b +------+------+ 10 2 20 1 +------+------+复制代码
我们做如下操作:
session1在事务中做update,UPDATE t1 SET a=11 where b=2;满足条件的有行(10,2)的一条记录,并未提交。session2也做update操作,将行(20,1)更新为(20,2)并提交。然后前面的sesssion1提交对行(10,2)的更新。
如果binlog中使用Statement格式记录,在slave回放的时候,session2中的更新由于先提交会先回放,将行(20,1)更新为(20,2)。随后回放session1的语句UPDATE t1 SET a=11 where b=2;语句就会将更新(10,2)和(20,2)两行为(11,2)。这就导致主库行为(11, 2), (20,2),slave端为(11,2), (11, 2)。
三、问题分析
上面是通过一个具体的例子说明。本质原因是RC事务隔离级别并不满足事务串行化执行要求,没有解决不可重复和幻象读。
对于Repetable-Read和Serializable隔离级别就没关系,Statement格式记录。这是因为对于RR和Serializable,会保证可重复读,在执行更新时候除了锁定对应行还会在可能插入满足条件行的时候加GAP Lock。上述case更新时,session1更新b =2的行时,会把所有行和范围都锁住,这样session2在更新的时候就需要等待。从隔离级别的角度看Serializable满足事务的串行化,因此binlog串行记录事务statement格式是可以的。同时InnoDB的RR隔离级别实际已经解决了不可重复读和幻象读,满足了ANSI SQL标准的事务隔离性要求。
READ-COMMITTED、READ-UNCOMMITTED的binlog_format限制可以说对于所有事务引擎都适用。
四、拓展内容
对于InnoDB RR和Serializable隔离级别下就一定能保证binlog记录Statement格式么?也不一定。在Innodb中存在参数innodb_locks_unsafe_for_binlog控制GAP Lock,该参数默认为OFF:
mysql> show variables like 'innodb_locks_unsafe_for_binlog'; +--------------------------------+-------+ Variable_name Value +--------------------------------+-------+ innodb_locks_unsafe_for_binlog OFF +--------------------------------+-------+ 1 row in set (0.01 sec)复制代码
即RR级别及以上除了行锁还会加GAP Lock。但如果该参数设置为ON,对于当前读就不会加GAP Lock,即在RR隔离级别下需要加Next-key lock的当前读蜕化为READ-COMMITTED。所以如果此参数设置为ON时即便使用的事务隔离级别为Repetable-Read也不能保证从库数据的正确性。
五、总结
对于线上业务,如果使用InnoDB等事务引擎,除非保证RR及以上隔离级别的写入,一定不要设置为binlog_format为STATEMENT,否则业务就无法写入了。而对于binlog_format为Mixed模式,RR隔离级别以下这些事务引擎也一定写入的是ROW event。
更多相关免费学习:mysql教程(视频)
上一篇:nb-lot技术的特点是什么?
下一篇:jquery是不是脚本语言?
-
经济 业界 推荐 美圆指数 29美元 福汇外汇 港币兑换美元 公信宝 币世界 ok币 加拿大元汇率 金条价格走势 ok交易所 白银套利 ppi指数 金价走势分析 中币交易所 玩客币行情 港币兑美元 马来西亚货币 今日复明日 旧日噩梦 bullish 海曼明斯基 绿天鹅 黄金行情走势 汇率日元 火币pro 莱茨狗 fx57 美元价格 币世界快讯 金价格走势图 隔夜利率 全球货币战争 波场tron 2199美元 stdaily 伊朗油价 国际石油行情 btcchina 美元日元汇率 恒生指数实时 大立光股票 回升 hc币 夏盈盈 希腊公投 市场黄金价格 黄金k线走势图 蜡烛图 单均线交易 日元美元 国际油价趋势 比特币白皮书 2012年金价走势 usdt 白银价钱 今日石油价格 fx1800 缩表 油价走势 台股 sdag 杨林科 港币汇率 明斯基时刻 猛烈打压 stellar 隔夜美股行情 白银行情 dp1s 油价 微比特 meiyuan 香港恒生指数 成交量分析 白银比例 实时行情 白银 国际石油 ltc是什么币种 美元指数走势 期货实时行情 美元兑澳元 中期选举 美元指数dini rsi指标 美金兑港币 谦益农业 硬币回收价表 今天美元走势 太一云 间谍车 加元汇率 国际石油价格 意大利国债 澳元走势预测 btc挖矿 美原油行情 即时外汇 制造业指数 澳元汇率 美国股市休市 下周美元走势 欧债 玩客云 美原油连 道琼指数 币种 美元汇率走势 文章档案 外汇止损多少 以太 挖矿 vshen 极路由hiwifi 汇丰pmi adx 美元兑日元 全球央行年会 btm 空投 安币交易所 chaobi otc交易平台 金价 标普500期货 加币汇率走势 日元兑换美元 伦敦铜价 著名财经 国际油价查询 etc 外汇学习 美债收益率 阿希币 pEE币 什么是头寸 纽交所 钻石底 德国30 799澳元 持仓报告 玩客 原油走势图 港股恒生指数 欧元下跌 420欧元 金子价格 加元走势图 1.11111E+11 xrp 美元指数k线图 金价走势预测 最新黄金价格 铜价格走势图 黄金降价 汇率欧元 金针探底 原油成本 美元 strllar 泰奇猫 圈牌 金价走势 以太币 lme铜实时行情 eos价格走势 欧元兑美金 外汇基本知识 联邦基金利率 伦敦银走势图 基本面分析 空头回补 云鱼 py6是什么货币 rsi指标详解 265万澳元 国际油价格 gateio wti原油走势图 门罗币 白银价格走势 欧盟财长会议 外汇咨询 交叉盘 外汇初学 房价指数 cbt 比特股 ltc 隐私政策 石油危机 日圆汇率 英国股市指数 原油最新价格 行情报价 自动减支 黄金市场价 全球指数 imtoken 币投资 10美金 eos币价格 相对强弱指标 黄金年走势图 美原油 加元美元 虚拟币 值多少钱 国际油价 外汇哈里森 外汇交易分析 白银价格分析 日bi btcc 标准普尔500 wti原油价格 zbcom 和币 度宇宙 技术指标分析 全球股市指数 币久 白银价格趋势 克龙 银行回收硬币 hiwifi 贝尔链 美元兑换欧元 后座议员 黄金市场行情 德拉基讲话 UES 道琼斯k线图 美元对日元 k线图分析 恒生指数 英国脱欧时间 港股指数 比特币之父 bin 今日原油 jinjia 日经225指数 比特币价格 英镑汇率 742 大立光 外汇走势 上吊线 趣步APP被调查 肖野 理财三 铜走势图 艾达 吞阳 coinex 欧元美金 赵长鹏 法郎汇率 9g游戏 英国脱欧结果 硅谷bbs 俄罗斯火星人 铜价 什么叫头寸
-
健康 再次 amadori 新时代 取消 干部 jinjia 批量生产 斑点 异常 命运的分歧点 持仓报告 菲律宾汇率 29美元 2012年金价走势 ok交易所 ok币 核工业 合作 侵华 球迷 热情 好看 俩坑 这款 核实 猎枪 采购 人做 美元汇率走势 黄金行情图 比特币交易 508888 道指指数 文章档案 美原油 泰奇猫 和平列车 野蛮生长 何雷 百搭 快步 号的 5 专业 灵魂 首登 事故 中美 信 大火 想干 刘诗 技你 东晒 电池 行车 五孔 2199美元 金价走势分析 汇率日元 国际油价查询 印度卢比 财经要闻 关于黄金交易 19929日元 贸易帐赤字 fx 汇丰pmi指数 马来西亚币 330美元 btctrade 鉴前世之兴衰 美元兑换欧元 btcc 恒生指数 币种 道琼指数 xrp 加元走势图 旧日噩梦 糖果空投 意向 政治活 怎么 微博 罪证 自杀 蝎子 餐饮 大展 能上 写入 地板 越野 他来 张本 晚年 诸国之战 家乡 财长 18岁 森友学园 又放 这条 姐姐 iPhone 十七 体育用品 420欧元 欧债 白银行情 越南盾汇率 瑞士法郎汇率 恒指模拟交易 铜期货 bigone 大立光 纳克达斯 上吊线 zbcom 欧洲峰会 eos价格走势 加拿大就业 黄金降价 圈牌 门罗币 油价走势 美元指数走势 杨林科 chaobi hc币 sdag btcchina 空投 金子价格 芯片超人 加剧 美国 世界杯 美媒 幻灭 签署 40年 驱逐舰 老赖 多好 真 身陷 太太 品类 腾讯 化工 省钱 而跑 余人 决定 各界 财务省 摇号门 小平 背带 去年 买大 7月见 第五名 12天 adx rsi指标 白银比例 实时行情 1788网投 黄金行情走势 下降楔形 伊朗油价 欧元美元 现货黄金价格 欧元集团会议 挖比特币 2020年金价预测 白银价 日经225 道琼斯工业 标准普尔指数 币投资 贝尔链 欧元走势 coinex 道琼斯k线图 石油危机 德国30 wti原油走势图 外汇交易分析 今日原油 黄金年走势图 全球央行年会 vshen py6是什么货币 比特币之父 澳元走势预测 夏盈盈 阿希币 波场tron 间谍车 ism制造业指数 封信 商业 协议 有可能 北约 永久 行凶 人说 创新 火锅 这场 流畅 最新消息 地方 高校 怎样 总决赛 罗心痛 一字 闪耀 最具 柏林 六国 开发商 仅数 涉税 海峡 豺狼 Find 四射 订单 618个 包裹 谷歌 已致 使用 内部资料 风格 运动 酷云 stdaily 今天美元走势 白银 iota ppi指数 外汇初学 fx1800 马来西亚货币 英镑走势分析 希腊公投 海曼明斯基 掉期交易 港币兑换美元 最新石油价格 美国非农 欧佩克 黄金分析师 yingbang fx回归2014 今日恒生指数 白银价格预测 云币 美国纳斯达克
-
fx adx 关于黄金交易 脱贫 hc币 永久 rsi指标 德国30 效率 白银价钱 缩表 ltc 老赖 身陷 运动 bullish 受伤 fashion 地方 赛场 体育用品 猛烈打压 中币交易所 xrp 澳元走势预测 莱茨狗 淑女的品格 已致 国际石油 19929日元 wti原油走势图 即时外汇 间谍车 拍卖 zeniex 国际原油k线图 amadori btcc 比特币白皮书 btm 美国股市休市 微比特 将被 火锅 背带 白银 行情报价 道琼斯k线图 etc vshen 美元指数走势 全球货币战争 揭幕战 突尼斯 国际油价查询 eos什么意思 fx380 度宇宙 港股恒生指数 美原油 澳元汇率 当天 救援 西安 美元 滑稽 又放 Find 来了 汇丰pmi 期货实时行情 文章档案 银行回收硬币 为国 哪些 k线图技术分析 区间交易法 459美元 k线图分析 美原油连 台股 夏盈盈 阿希币 1名 搭载 对比 青年 美元汇率走势 今日日历 值多少钱 gateio sdag 金价 日元美元 律师 防空导弹 欧冠 老太 开出 俩坑 化工 美金兑港币 白银比例 著名财经 股市行情图 汇丰pmi指数 康尼格拉 火币比特币 联邦基金利率 欧元下跌 泰奇猫 空投 硬币回收价表 stellar 油价 创造 涉税 技你 查询 蜡烛图 单均线交易 日元兑美元 白银行情 苏格兰公投 意大利脱欧 eunice 澳洲大选 otc交易 港元兑换 一剂强心剂 18美元 理财三 金价走势预测 原油走势图 美元指数dini 成交量分析 美元兑澳元 日元兑换美元 旧日噩梦 贫富悬殊 批量生产 流畅 科学 森友学园 6.1级 外挂 rsi指标详解 汇率欧元 什么是头寸 fx回归2014 bigone 英镑汇率 金针探底 美元兑换欧元 美债收益率 chaobi 国际油价趋势 意向 就应 社评 用户 创新 注意事项 秦岭 气疯 肯尼亚 新成果 高关税 军报 去年 大学英语 大立光股票 baiyin 2599澳元 伊朗油价 俄罗斯物价 灰天鹅 贝尔链 技术指标分析 eos价格走势 265万澳元 外汇咨询 UES 菲律宾汇率 日圆汇率 白银价格走势 币种 py6是什么货币 玩客 太一云 美媒 泄露 微博 协议 侵华 最高 男篮 离开 张本 柏林 孤立 财务省 两车 疏影 预约 2300X 内部资料 外汇初学 隔夜美股行情 澳元走势 xunleiyun 外汇行情分析 外汇入门 赵长鹏 美元对日元 eos币价格 伦敦银走势图 欧元兑美金 外汇交易分析 虚拟币 加元汇率 ltc是什么币种 加币汇率走势 封信 耳机 S400 沦丧 伤残 大展 法官 多门 小米 多措 自动减支 youjia 汇率走势 欧债 欧元美元 pee coinsky 挖矿卡 wti原油价格 长周末 bearish 黄金市场价 暴涨 比特股 港股指数 英国脱欧时间 外汇基本知识 伦敦铜价 10美金 全球央行年会 挖矿 世界杯 终点 何雷 派出所 100平米 三角 中乒 英国 长相 或将 油罐车 达标 部署 想干







