Mysql之二进制日志
目录
二进制日志 12-37
二进制日志格式
基于行的二进制日志
基于语句的二进制日志
混合格式二进制日志
复制日志 12-42
故障安全 (Crash-Safe) 复制
多源复制
二进制日志 12-37
二进制日志:• 包含数据和模式更改及其时间戳– 基于语句 或 基于行 的日志记录• 用于从备份的时间点恢复、从备份的完全恢复和复制• 在下列情况下轮转:– MySQL 重新启动– 其达到 max_binlog_size 设置的最大大小– 发出 FLUSH LOGS 语句• 可以通过各种方式进行检查:– 元数据:SHOW BINARY LOGS, SHOW MASTER STATUS– 内容:mysqlbinlog
二进制日志格式
• MySQL以三种不同格式之一在二进制日志中记录信息:– 基于行的日志记录(默认方法)– 基于语句的日志记录– 混合记录• 通过启动全局或会话 binlog_format 服务器变量来更改二进制日志格式:SET [GLOBAL|SESSION] BINLOG_FORMAT=[row|statement|mixed|default];• 不能在运行时设置 binlog_format 变量:– 从存储函数或触发器中– 如果NDB存储引擎已启用– 如果会话当前正在使用基于行的复制,则临时表会
基于行的二进制日志
• 基于行的二进制日志:– 是默认的二进制日志格式– 记录对单个表行的更改更新多行时会生成更大的日志日志中记录的值与发送到存储引擎的值完全相同每个表都需要一个主键来正确标识每一行从属服务器上需要的 DML 锁更少– 能始终正确重放语句,即使语句是不确定的例如:CURRENT_USER() 或 CONNECTION_ID()• 主服务器和从属服务器必须使用相同的表结构
基于语句的二进制日志
• 包含实际的 SQL 语句– 可用于审计– 更容易识别用于时间点恢复的语句• 包括 DDL (CREATE, DROP, 等) 和 DML (UPDATE, DELETE, 等) 语句• 由于所需的文件大小相对较小,因此节省了磁盘空间和网络带宽– 当一条 SQL 语句修改多行时• 不能保证非确定性语句在远程机器上的正确重放– 如果 MySQL 不能保证这一点,它就会发出警告:Statement may not be safe to log instatement format
混合格式二进制日志
• 默认情况下使用基于语句的日志记录• 当语句不确定时会使用基于行的日志记录:– 调用 UUID(), USER(), FOUND_ROWS(), ROWS_COUNT(), 或任何用户定义的函数– 当一个或多个具有 AUTO_INCREMENT 列的表被更新并调用触发器或存储函数时– 当语句引用系统变量时– 某些涉及视图或临时表的情况
复制日志 12-42
从属服务器维护有关复制事件的信息• 中继日志集:– 包括中继日志和中继日志索引文件– 包含来自主服务器的二进制日志事件的副本• 从属服务器状态日志:– 包含执行复制所需的信息主服务器连接详细信息和日志坐标中继日志坐标– 存储在表(默认)或文件中在 mysql 数据库的 slave_master_info 和 slave_relay_log_info 表默认文件名称:master.info 和 relay-log.info
故障安全 (Crash-Safe) 复制
• 二进制日志记录是故障安全的:– MySQL 仅记录完成的事件或事务– 使用 sync-binlog 提高安全性默认值是 1,最安全的,操作系统在每次事务后写入文件将 sync-binlog 设置为 0,当操作系统根据其内部规则写入文件的同时服务器崩溃时,性能最好但事务丢失的可能性最大将该值设置为大于 1 的任何数字以在该数量的事务之后写入• 将从属服务器状态日志存储在表中以进行故障安全复制。– 选项:master-info-repository 和 relay-log-info-repository可能值为 FILE(默认值)和 TABLETABLE 是故障安全的
多源复制
• 使复制从属服务器能够同时从多个主服务器接收事务– 至少需要两个主服务器和一个从属服务器设备– 从属服务器为每个主服务器创建一个 复制通道– 从属服务器必须使用 基于表 的资料档案库多源复制与 基于文件 的资料档案库不兼容• 不尝试检测或解决冲突– 如果需要此功能,则由应用程序负责• Enables:– 将多台服务器备份到一台服务器– 将多台服务器的数据整合到一台服务器– 合并表的分片
相关文章:
Mysql之二进制日志
目录 二进制日志 12-37 二进制日志格式 基于行的二进制日志 基于语句的二进制日志 混合格式二进制日志 复制日志 12-42 故障安全 (Crash-Safe) 复制 多源复制 二进制日志 12-37 二进制日志: • 包含数据和模式更改及其时间戳 – 基于语句 或 基于行 的日志…...
kail工具的使用--- cewl
1.介绍 Cewl是一款采用Ruby开发的应用程序,可以给他的爬虫指定URL地址和爬取深度,还可以添加外部链接,接下来Cewl会给你返回一个字典文件,你可以把字典用到类似John the Ripper这样的密码破解工具中。 2.使用 输入以下命令之后…...
【蓝桥杯集训1】前缀和专题(2 / 5)
目录 前缀和模板 !3956. 截断数组 - 前缀和枚举 前缀和模板 活动 - AcWing import java.util.*;class Main {static int N100010;static int[] anew int[N],snew int[N];public static void main(String[] args){Scanner scnew Scanner(System.in);int nsc.nex…...
基于模块联邦的微前端实现方案
一、 微前端应用案例概述 当前案例中包含三个微应用,分别为 Marketing、Authentication 和 Dashboard Marketing:营销微应用,包含首页组件和价格组件 Authentication:身份验证微应用,包含登录组件 Dashboard&#x…...
【单目标优化算法】食肉植物优化算法(Matlab代码实现)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...
ANTLR4入门学习(四)
ANTLR4入门学习(四)一、设计语法1.语法2.ANTLR核心标记3.常见计算机语言模式4.左右递归5.识别常见的语法结构5.1 匹配标识符5.2 匹配数字5.3 匹配字符串常量5.4 匹配注释和空白字符5.5 基础的语法规则5.6 划定词法分析器和语法分析器的界线一、设计语法 …...
Android okhttp3中发送websocket消息,并通过mockwebserver将一个安卓设备模拟成服务器接发消息
websocket 提供了客户端和服务端的长链接,允许客户端和服务端双向发送消息 okhttp 提供了使用websocket 相关接口议。同时为方便单元测试,又提供了mockwebserver可以把一个安卓客户端作为服务端接受消息。 websocket使用 权限 <uses-permission an…...
MySQL系统变量和自定义变量
1 系统变量1.1 查看系统变量可以使用以下命令查看 MySQL 中所有的全局变量信息。SHOW GLOBAL VARIABLES; MySQL 中的系统变量以两个“”开头。global 仅仅用于标记全局变量;session 仅仅用于标记会话变量;首先标记会话变量,如果会话变量不存在…...
基于Python来爬取某音动态壁纸,桌面更香了!
至于小伙伴们想要这个封图,我也没有。不过继续带来一波靓丽壁纸,而且是动态的,我的桌面壁纸又换了:每天换着花样欣赏一波波动态壁纸桌面立刻拥有了高颜值,简直跟刷美女短视频一样啊。对的,这些动态壁纸就是…...
[数据库]表的约束
●🧑个人主页:你帅你先说. ●📃欢迎点赞👍关注💡收藏💖 ●📖既选择了远方,便只顾风雨兼程。 ●🤟欢迎大家有问题随时私信我! ●🧐版权:本文由[你帅…...
VisualGDB 5.6R9 FOR WINDOWS
Go cross-platform with comfort VisualGDB 是 Visual Studio 的一个非常强大的扩展,它允许您调试或调试嵌入式系统。这个程序有一个非常有吸引力的用户界面,它有许多调试或调试代码的功能。VisualGDB 还有一个向导可以帮助您调试程序,为您提…...
Yolov8的多目标跟踪实现
Yolov8_tracking 2023年2月,Yolov5发展到yolov8,这世界变得真快哦。Yolov8由ultralytics公司发布,yolov6-美团,yolov7-Alexey Bochkovskiy和Chien-Yao Wang,其各有高招,对yolov5均有提升。mikel-brostrom在…...
28--Django-后端开发-drf之自定义全局异常、接口文档生成以及三大认证源码分析
一、django请求的整个生命周期 旅程: drf处于的位置:路由匹配成功,进视图类之前 1、包装了新的request 2、处理了编码(urlencoded,formdata,json) 3、三大认证 4、进了视图类(GenericAPIView+ListModelMixin) 进行了过滤和排序去模型中取数据分页序列化返回5、处理了…...
【MyBatis】动态SQL
9、动态SQL Mybatis框架的动态SQL技术是一种根据特定条件动态拼装SQL语句的功能,它存在的意义是为了解决拼接SQL语句字符串时的痛点问题。 9.1、if if标签可通过test属性的表达式进行判断,若表达式的结果为true,则标签中的内容会执行&…...
LeetCode(剑指offer) Day1
1.用两个栈实现一个队列。队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的功能。(若队列中没有元素,deleteHead 操作返回 -1 ) 解题过程记录:本题就是用两个栈&…...
1、MyBatis框架——JDBC代码回顾与分析、lombok插件的安装与使用
目录 一、JDBC基本操作步骤 二、JDBC代码 三、lombok插件的安装与使用 1、lombok插件的安装 2、lombok常用注解 Data Getter Setter ToString AllArgsConstructor NoArgsConstructor 3、lombok的使用 四、JDBC代码分析 一、JDBC基本操作步骤 1、导包mysql-connect…...
笔记-GPS设备定位方式
1. 背景 最近接触到的GPS设备有点多,逐渐明白大家定位的机理,也结合网上的文章《GPS、WiFi、基站、AGPS几种定位原理介绍与区别》 来做一个简单的总结。 2. 基于GPS定位 这是最基本的定位能力,它主要就是寻找卫星,利用光传播速度…...
2023秋招携程SRE算法岗面试经验分享
本专栏分享 计算机小伙伴秋招春招找工作的面试经验和面试的详情知识点 专栏首页:秋招算法类面经分享 主要分享计算机算法类在面试互联网公司时候一些真实的经验 面试code学习参考请看:...
4.9 内部类
文章目录1.内部类概述2.特点3.练习 : 内部类入门案例4.成员内部类4.1 练习 : 被private修饰4.2 练习 : 被static修饰5.局部内部类6.匿名内部类1.内部类概述 如果一个类存在的意义就是为指定的另一个类,可以把这个类放入另一个类的内部。 就是把类定义在类的内部的情…...
ncnn模型精度验证
验证ncnn模型的精度 1、进行pth模型的验证 得到ncnn模型的顺序为:.pth–>.onnx–>ncnn .pth的精度验证如下: 如进行的是二分类: model init_model(model, data_cfg, devicedevice, modeeval)###.pth转.onnx模型# #---# input_names …...
TTS-Backup:Tabletop Simulator数据备份与资源管理的技术解决方案
TTS-Backup:Tabletop Simulator数据备份与资源管理的技术解决方案 【免费下载链接】tts-backup Backup Tabletop Simulator saves and assets into comprehensive Zip files. 项目地址: https://gitcode.com/gh_mirrors/tt/tts-backup 在数字桌游时代&#x…...
给MT7628路由器插上4G翅膀:OpenWRT下EC20模块保姆级配置与避坑指南
让老旧路由器重获新生:MT7628EC20打造高性价比4G物联网网关 在物联网和边缘计算快速发展的今天,稳定可靠的网络连接成为各类智能设备的基础需求。然而传统有线宽带在移动监控、车载设备、临时部署等场景中往往难以满足需求。本文将详细介绍如何利用MT762…...
别再只当SIM卡用了!用Python脚本和APDU命令,带你亲手“解剖”手机卡里的文件系统
用Python和APDU命令探索USIM卡文件系统的实战指南 当你把手机卡插入设备时,它不仅仅是一个身份标识——实际上,这是一套完整的微型操作系统。本文将带你用Python脚本和APDU命令,像安全研究员一样亲手探索USIM卡内的文件系统结构。 1. 准备工作…...
Ajax技术和Axois工具库
前端如何才能动态展示数据?如何动态获取后端的数据呢? 目录 文章目录 一、什么是Ajax? 二、什么是Axios? 核心用途 三、如何在Vue项目中使用Axios? 1、安装Axios 2、引入Axios 3、基础使用 4、拦截器 5、async/await是什么? 总…...
微信工具箱终极指南:3分钟快速掌握微信自动化管理技巧
微信工具箱终极指南:3分钟快速掌握微信自动化管理技巧 【免费下载链接】wechat-toolbox WeChat toolbox(微信工具箱) 项目地址: https://gitcode.com/gh_mirrors/we/wechat-toolbox 你是否厌倦了手动整理微信通讯录的繁琐?…...
Postmate部署实战:从开发到生产的完整流程
Postmate部署实战:从开发到生产的完整流程 【免费下载链接】postmate 📭 A powerful, simple, promise-based postMessage library. 项目地址: https://gitcode.com/gh_mirrors/po/postmate Postmate是一个强大的、简单的、基于Promise的postMess…...
Arm GIC虚拟中断控制器架构与寄存器详解
1. Arm GIC虚拟中断控制器架构概述 中断控制器是现代处理器架构中的关键组件,负责协调和管理来自各种外设的中断请求。在虚拟化环境中,传统的中断控制器面临新的挑战:如何高效处理来自多个虚拟机的中断请求,同时保持隔离性和性能。…...
学生党福音:用最便宜的TT马达和STM32F103C8T6,我焊出了能遥控的平衡小车
低成本DIY平衡小车:TT马达与STM32的极致性价比方案 当我在宿舍里第一次看到那辆价值近千元的商业平衡小车时,脑海中立刻浮现出一个问题:能不能用更便宜的材料实现类似功能?作为一名预算有限的学生,我开始探索如何用最…...
视觉语言模型心智理论评估:意图理解与视角采样的能力分离现象
1. 项目概述:当AI“读心术”遇到瓶颈最近在跟进多模态大模型的前沿进展时,一篇来自2025年“心智理论”国际研讨会的论文引起了我的注意。论文标题很有意思,叫《视觉语言模型看到你想看的,而非你看到的》。这个标题精准地概括了当前…...
家政派单小程序源头厂家
随着现代生活节奏的加快,家政服务的需求日益增长。为了满足这一需求,许多公司开始推出家政派单小程序,以提供更便捷、高效的服务体验。然而,在众多的选择面前,如何找到一家真正能够满足自身业务需求的源头厂家呢&#…...
