MySQL binlog的三种模式

MySQL 的 binlog(Binary Log) 默认的模式是 STATEMENT,即 语句模式。在这种模式下,MySQL 会记录所有对数据库执行的数据修改操作(如 INSERTUPDATEDELETE 等)的 SQL 语句。


1. binlog 的三种模式

MySQL 的 binlog 支持三种记录模式,分别是:

  1. STATEMENT(语句模式)
    • 记录实际执行的 SQL 语句。
    • 默认模式。
  2. ROW(行模式)
    • 记录每一行数据的修改细节。
    • 例如,UPDATE 操作会记录修改前后的整行数据。
  3. MIXED(混合模式)
    • 结合 STATEMENT 和 ROW 模式。
    • 默认使用 STATEMENT 模式,但在某些情况下自动切换到 ROW 模式。

2. 默认模式:STATEMENT

  • 特点
    • 记录 SQL 语句,而不是实际修改的数据。
    • 日志文件较小,节省存储空间。
    • 在某些情况下可能导致主从复制不一致(如使用非确定性函数 NOW()RAND() 等)。
  • 适用场景
    • 适合简单的 SQL 操作,且不涉及非确定性函数的场景。

3. 如何查看和修改 binlog 模式

3.1 查看当前 binlog 模式
SHOW VARIABLES LIKE 'binlog_format';
  • 返回结果示例:
    +---------------+-----------+
    | Variable_name | Value     |
    +---------------+-----------+
    | binlog_format | STATEMENT |
    +---------------+-----------+
    
3.2 修改 binlog 模式

可以通过以下方式修改 binlog 模式:

  1. 临时修改(重启后失效):
    SET GLOBAL binlog_format = 'ROW';
    
  2. 永久修改(修改配置文件):
    • 编辑 MySQL 配置文件(如 my.cnfmy.ini),添加或修改以下内容:
      [mysqld]
      binlog_format = ROW
      
    • 重启 MySQL 服务使配置生效。

4. 不同模式的对比

模式记录内容优点缺点适用场景
STATEMENTSQL 语句日志文件小,节省存储空间可能导致主从复制不一致简单 SQL 操作,无非确定性函数
ROW每一行数据的修改细节数据一致性强,支持复杂操作日志文件较大,占用更多存储空间复杂 SQL 操作,涉及非确定性函数
MIXED结合 STATEMENT 和 ROW 模式兼顾日志大小和数据一致性需要根据场景自动切换模式通用场景

5. 选择 binlog 模式的建议

  1. STATEMENT
    • 适合简单场景,且不涉及非确定性函数。
    • 日志文件较小,适合存储空间有限的场景。
  2. ROW
    • 适合复杂场景,涉及非确定性函数或需要强一致性。
    • 日志文件较大,但数据一致性更强。
  3. MIXED
    • 适合通用场景,兼顾日志大小和数据一致性。

6. 总结

  • MySQL 的 binlog 默认模式是 STATEMENT
  • 可以通过 SHOW VARIABLES 查看当前模式,通过 SET GLOBAL 或修改配置文件调整模式。
  • 根据实际需求选择合适的 binlog 模式,以平衡日志大小、数据一致性和性能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/69923.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

25农村发展研究生复试面试问题汇总 农村发展专业知识问题很全! 农村发展复试全流程攻略 农村发展考研复试真题汇总

农村发展复试当然有好的建议!前提是复试重点面试题背好! 你是不是也在为农村发展考研复试发愁?担心自己准备不充分、表现不好?别急!今天,学姐——复试面试拿下90分成功上岸的学姐,来给大家分享…

读取本地excel并生成map,key为第一列,value为第二列

添加依赖&#xff1a;在 pom.xml 文件中添加以下依赖&#xff1a; <dependencies><dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>5.2.3</version></dependency><dependency&…

代码随想录算法【Day44】

Day44 1143.最长公共子序列 class Solution { public:int longestCommonSubsequence(string text1, string text2) {vector<vector<int>> dp(text1.size() 1, vector<int>(text2.size() 1, 0));for (int i 1; i < text1.size(); i) {for (int j 1; …

【transformers.Trainer填坑】在自定义compute_metrics时logits和labels数据维度不一致问题

问题描述 我在使用 transformers.Trainer 训练我的模型时&#xff0c;我自定义了 compute_loss 函数和compute_metrics函数&#xff0c;我的模型是一个简单的二分类模型。 在自定义 compute_loss 时这样写的&#xff1a; def compute_loss(self, model, inputs, return_outp…

论文学习记录之《CLR-VMB》

目录 一、基本介绍 二、介绍 三、方法 3.1 FWI中的数据驱动方法 3.2 CLR-VMB理论 3.3 注意力块 四、网络结构 4.1 网络架构 4.2 损失函数 五、实验 5.1 数据准备 5.2 实验设置 5.3 训练和测试 5.4 定量分析 5.5 CLR方案的有效性 5.6 鲁棒性 5.7 泛化性 六、讨…

【STM32】舵机SG90

1.舵机原理 舵机内部有一个电位器&#xff0c;当转轴随电机旋转&#xff0c;电位器的电压会发生改变&#xff0c;电压会带动转一定的角度&#xff0c;舵机中的控制板就会电位器输出的电压所代表的角度&#xff0c;与输入的PWM所代表的角度进行比较&#xff0c;从而得出一个旋转…

算法刷题-链表系列-移除链表、设计链表、翻转列表

题目要求 所有主要考察对链表的增删查改的功能 总结 对于有些从头遍历到尾的方法&#xff0c;创建一个头结点使得所有的结点能以统一的方式且全部被遍历到&#xff0c;不会出现头结点不被遍历的问题。对于遍历的条件&#xff0c;有的时候curNode ! nullptr&#xff0c;有的时…

Django项目中创建app并快速上手(pycharm Windows)

1.打开终端 我选择的是第二个 2.运行命令 python manage.py startapp 名称 例如&#xff1a; python manage.py startapp app01 回车&#xff0c;等待一下&#xff0c;出现app01的文件夹说明创建成功 3.快速上手 1.app注册 增加一行 "app01.apps.App01Config"&#…

Windows系统安装搭建悟空crm客户管理系统 教程

1、在安装悟空 CRM 之前&#xff0c;需要确保你的 Windows 系统上已经安装了以下软件&#xff1a; Web 服务器&#xff1a;推荐使用 Apache 或 Nginx&#xff0c;这里以 Nginx 为例。你可以使用集成环境套件如 XAMPP 来简化安装过程&#xff0c;它包含了 Nginx 、MySQL、PHP 等…

深度学习框架探秘|TensorFlow vs PyTorch:AI 框架的巅峰对决

在深度学习框架中&#xff0c;TensorFlow 和 PyTorch 无疑是两大明星框架。前面两篇文章我们分别介绍了 TensorFlow&#xff08;点击查看&#xff09; 和 PyTorch&#xff08;点击查看&#xff09;。它们引领着 AI 开发的潮流&#xff0c;吸引着无数开发者投身其中。但这两大框…

java每日精进 2.13 Ganache(区块链本地私有化部署)

需求&#xff1a;使用区块链实现数据村存储&#xff0c;记录一些不可篡改的交互信息&#xff0c;网络环境为内外网均需要部署&#xff1b; 1.准备工作&#xff08;软件安装&#xff09; 1.1 安装 Node.js 和 npm 1.2 安装 Ganache 地址如下&#xff1a;windows有可视化界面 &a…

w206基于Spring Boot的农商对接系统的设计与实现

&#x1f64a;作者简介&#xff1a;多年一线开发工作经验&#xff0c;原创团队&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取&#xff0c;记得注明来意哦~&#x1f339;赠送计算机毕业设计600个选题excel文…

chrome://version/

浏览器输入&#xff1a; chrome://version/ Google浏览器版本号以及安装路径 Google Chrome131.0.6778.205 (正式版本) &#xff08;64 位&#xff09; (cohort: Stable) 修订版本81b36b9535e3e3b610a52df3da48cd81362ec860-refs/branch-heads/6778_155{#8}操作系统Windows…

哈希槽算法与一致性哈希算法比较

Redis 集群模式使用的 哈希槽&#xff08;Hash Slot&#xff09; 算法与传统的 一致性哈希&#xff08;Consistent Hashing&#xff09; 算法在数据分布和节点管理上有显著的区别。以下是两者的详细比较&#xff1a; 1. Redis 哈希槽算法 1.1 基本原理 Redis 集群将整个数据集…

【BUUCTF逆向题】[WUSTCTF2020]level3(魔改base64)

一.[WUSTCTF2020]level3 打开IDA反汇编&#xff0c;发现就是base64加密 这里rand就是与&搭配设置奇偶数2分随机 但是根据提示不是标准base64加密 首先想到魔改密码表&#xff0c;追踪进去&#xff0c;发现没有什么变化啊 尝试对Base64字符串解码也不对 追踪密码表CtrlX发…

有关Java中的接口

学习目标 掌握接口语法理解接口多态熟练使用接口了解接口新特性掌握final关键字了解lambda语法 1.接口语法 1.1 接口概念 从功能上看, 实现接口就意味着扩展了某些功能 接口与类之间不必满足is-a的关系结构 从抽象上看, 接口是特殊的抽象父类 从规则上看, 接口定义者和实…

鸿蒙(openharmony) 5.0 光感接口崩溃

目录 1.背景 2.解决方案 1.背景 使用OpenHarmony 5.0调用光感接口崩溃,返回的值是undefined,接口如下: sensor.on(sensor.SensorId.AMBIENT_LIGHT, (data) => {if (data == null || data == undefined || data.intensity == null || data.intensity == undefined) {ret…

git用法(简易版)

介绍 git是一个版本管理工具 使用方法 建立仓库 第一步 git init&#xff1a;初始化仓库 第二步 git add .&#xff1a;将代码添加到暂存区 第三步 git commit -m "first"&#xff1a;为修改添加备注 第四步 git remote add origin 你的url 第五步 git pus…

【C++八股】内存泄漏

内存泄漏&#xff08;Memory Leak&#xff09;是指程序在动态分配内存后&#xff0c;未能及时释放已分配的内存&#xff0c;导致这些内存无法被再次使用&#xff0c;从而造成系统内存的浪费。随着时间的推移&#xff0c;内存泄漏可能导致程序性能下降&#xff0c;甚至系统崩溃。…

sqli-labs时间盲注和布尔盲注

1、时间盲注和布尔盲注 在SQL注入攻击中&#xff0c;时间盲注&#xff08;Time-Based Blind SQL Injection&#xff09;和布尔盲注&#xff08;Boolean-Based Blind SQL Injection&#xff09;是两种常见的技术&#xff0c;用于在无法直接获取数据的情况下推断数据库信息。 2…