mysql binlog查看指定数据库
1.mysql binlog查看指定数据库的方法
MySQL 的 binlog(二进制日志)主要记录了数据库上执行的所有更改数据的 SQL 语句,包括数据的插入、更新和删除等操作。但直接查看 binlog 并不直观,因为它是以二进制格式存储的。为了查看 binlog 中的内容,我们通常使用 mysqlbinlog
工具。
如果我们想查看指定数据库中 binlog 的内容,我们需要首先确定 binlog 文件的位置和名称,然后使用 mysqlbinlog
工具进行查看。以下是详细的步骤和示例:
1.1确定 binlog 文件的位置和名称
首先,我们需要知道 MySQL 的 binlog 文件保存在哪里。这通常可以在 MySQL 的配置文件(如 my.cnf
或 my.ini
)中找到,或者我们可以通过 SQL 查询来获取:
sql复制代码
SHOW VARIABLES LIKE 'log_bin%';
这会显示与 binlog 相关的变量,包括 log_bin
(指示是否启用 binlog)和 log_bin_basename
(binlog 文件的基本名称)。
1.2使用 mysqlbinlog 工具查看 binlog
假设我们已经找到了 binlog 文件的位置和名称(例如 /var/lib/mysql/binlog.000001
),我们可以使用 mysqlbinlog
工具来查看它。但是,直接查看整个 binlog 文件可能会包含很多内容,我们可能只对特定数据库的操作感兴趣。
为了过滤特定数据库的操作,我们可以使用 --database
选项。以下是一个示例命令:
bash复制代码
mysqlbinlog --database=your_database_name /var/lib/mysql/binlog.000001
这里 your_database_name
是我们想查看的数据库的名称。
1.3查看多个 binlog 文件
如果我们的操作跨越了多个 binlog 文件,我们可以使用通配符或列出所有相关的文件,并使用 mysqlbinlog
逐个查看它们,或者使用 mysqlbinlog
的 --start-datetime
和 --stop-datetime
选项来指定时间范围。
1.4将 binlog 内容导出为 SQL 文件
如果我们希望将 binlog 的内容导出为 SQL 文件以便稍后查看或分析,我们可以使用重定向操作符 >
:
bash复制代码
mysqlbinlog --database=your_database_name /var/lib/mysql/binlog.000001 > output.sql
这会将 binlog 的内容导出到名为 output.sql
的文件中。
1.5注意事项
-
确保我们有足够的权限来读取 binlog 文件。
-
如果 binlog 文件很大,查看或导出它们可能需要一些时间。
-
在生产环境中,直接查看或操作 binlog 可能会对性能产生影响,因此最好在低峰时段进行这些操作。
2.mysqlbinlog 是什么
mysqlbinlog
是 MySQL 提供的一个实用工具,用于处理二进制日志(binary log)文件。二进制日志是 MySQL 数据库管理系统用于记录数据库更改的日志文件,包括所有更改数据的 SQL 语句(如 INSERT、UPDATE、DELETE 等)以及可能的数据表结构更改(如 ALTER TABLE)。
mysqlbinlog
工具的主要用途包括:
(1)查看二进制日志内容:我们可以使用 mysqlbinlog
来查看二进制日志文件中记录的 SQL 语句,以便进行故障排查、审计或数据恢复。
(2)将二进制日志转换为 SQL 语句:通过 mysqlbinlog
,我们可以将二进制日志文件中的事件转换为 SQL 语句,并保存到一个文件中。这对于数据恢复或数据迁移特别有用。
(3)基于时间或位置的过滤:mysqlbinlog
允许我们基于时间戳或日志位置来过滤事件,只显示我们感兴趣的部分。
(4)重放二进制日志:在某些情况下,我们可能需要将二进制日志中的事件重放到另一个 MySQL 服务器或同一个服务器的另一个实例上。这通常用于数据复制或恢复。
(5)分析二进制日志:通过分析二进制日志,我们可以了解数据库的活动情况,例如哪些表或数据行被更改了,以及更改的频率等。
使用 mysqlbinlog
的基本语法如下:
bash复制代码
mysqlbinlog [options] log_file ...
其中 log_file
是我们要处理的二进制日志文件的名称,而 options
是可选的参数,用于指定如何处理日志文件。
例如,要查看名为 binlog.000001
的二进制日志文件中关于 mydatabase
数据库的所有事件,我们可以使用以下命令:
bash复制代码
mysqlbinlog --database=mydatabase binlog.000001
这将显示所有针对 mydatabase
数据库的 SQL 语句。
3.如何使用 mysqlbinlog
要使用 mysqlbinlog
工具查看 MySQL 的二进制日志(binlog),我们需要按照以下步骤操作:
3.1确定二进制日志的位置和文件名
首先,我们需要知道二进制日志文件存储在什么位置以及它们的文件名。我们可以通过 MySQL 命令行客户端来查看这些信息:
sql复制代码
SHOW BINARY LOGS;
这个命令会列出所有的二进制日志文件。
3.2使用 mysqlbinlog 工具
一旦我们知道了二进制日志的位置和文件名,我们就可以使用 mysqlbinlog
工具来查看它们了。在命令行中,我们可以这样调用 mysqlbinlog
:
bash复制代码
mysqlbinlog /path/to/binlog-file-name
其中 /path/to/binlog-file-name
是我们的二进制日志文件的完整路径和文件名。
3.3过滤特定的数据库或时间范围
如果我们只对某个特定数据库的操作感兴趣,我们可以使用 --database
选项来过滤结果:
bash复制代码
mysqlbinlog --database=your_database_name /path/to/binlog-file-name
如果我们想基于时间范围来过滤结果,可以使用 --start-datetime
和 --stop-datetime
选项:
bash复制代码
mysqlbinlog --start-datetime="2023-10-23 10:00:00" --stop-datetime="2023-10-23 14:00:00" /path/to/binlog-file-name
3.4将输出保存到文件
如果我们想把 mysqlbinlog
的输出保存到文件中,可以使用重定向操作符 >
:
bash复制代码
mysqlbinlog /path/to/binlog-file-name > output.sql
或者,如果我们在使用过滤选项,也可以这样做:
bash复制代码
mysqlbinlog --database=your_database_name /path/to/binlog-file-name > output.sql
3.5其他选项
mysqlbinlog
提供了许多其他选项和功能,我们可以通过 mysqlbinlog --help
命令来查看完整的选项列表和描述。
3.6注意事项
-
确保我们有足够的权限来读取二进制日志文件。
-
在处理大文件时,可能需要一些时间来完成。
-
如果我们在生产环境中使用二进制日志进行复制,请谨慎操作,以免影响复制过程。
-
在使用
--start-datetime
和--stop-datetime
选项时,请确保时间格式正确(YYYY-MM-DD HH:MM:SS)。
希望这些信息对我们有所帮助!如果我们有任何其他问题,请随时提问。
4.如何在 MySQL 中创建二进制日志文件
在 MySQL 中,二进制日志(也称为 binlog)主要用于复制和数据恢复。默认情况下,它可能不是启用的,但我们可以通过配置 MySQL 服务器来启用它。
以下是启用和配置 MySQL 二进制日志的步骤:
(1)编辑 MySQL 配置文件:
MySQL 的配置文件通常位于 /etc/mysql/my.cnf
(对于 Debian/Ubuntu 系统)或 /etc/my.cnf
(对于其他系统)。在某些系统上,它可能位于 /etc/mysql/mysql.conf.d/
下的某个子目录中。
打开配置文件,并找到 [mysqld]
部分。 (2)启用二进制日志:
在 [mysqld]
部分下,添加或修改以下行以启用二进制日志:
ini复制代码
log_bin = /var/log/mysql/mysql-bin.log
上述路径只是一个示例,我们可以将日志存储在任何我们希望的位置。确保 MySQL 用户有权写入该目录。 (3)(可选)设置二进制日志格式:
我们还可以设置二进制日志的格式。MySQL 支持三种格式:STATEMENT、ROW 和 MIXED。
-
STATEMENT
:基于 SQL 语句的日志记录。 -
ROW
:基于行的更改的日志记录。 -
MIXED
:混合了 STATEMENT 和 ROW 格式。
我们可以使用以下配置来设置格式:
ini复制代码
binlog_format = ROW
(1)(可选)设置二进制日志的过期时间:
我们可以设置二进制日志文件在被自动删除之前保留的时间长度。例如,如果我们想让文件在 7 天后被删除,可以添加:
ini复制代码
expire_logs_days = 7
(2)保存并关闭配置文件。
(3)重启 MySQL 服务器:
为了使更改生效,我们需要重启 MySQL 服务器。这可以通过以下命令之一完成(取决于我们的系统和安装方式):
sudo service mysql restart
# 或者
sudo systemctl restart mysql
(4)验证二进制日志是否已启用:
登录到 MySQL 并执行以下查询:
sql复制代码
SHOW VARIABLES LIKE 'log_bin%';
我们应该能看到 log_bin
的值是我们之前设置的路径,以及 log_bin_basename
和 log_bin_index
的相关值。
现在,MySQL 已经开始记录二进制日志了。这些日志对于复制、数据恢复和审计都是非常有用的。但是,请注意,启用二进制日志可能会增加一些磁盘 I/O 和 CPU 开销,特别是在高负载的服务器上。
相关文章:
mysql binlog查看指定数据库
1.mysql binlog查看指定数据库的方法 MySQL 的 binlog(二进制日志)主要记录了数据库上执行的所有更改数据的 SQL 语句,包括数据的插入、更新和删除等操作。但直接查看 binlog 并不直观,因为它是以二进制格式存储的。为了查看 bin…...

React + SpringBoot开发用户中心管理系统
用户中心项目搭建笔记 技术栈 前端技术栈 “react”: “^18.2.0”,ant-design-pro 后端技术栈 SpringBoot 2.6.x 项目源码地址 https://gitee.com/szxio/user-center 前端项目搭建 快速搭建一个后端管理系统项目框架 初始化 antDesignPro 官网: https://…...

移动机器人定位与导航实训记录
本次实训主要学习ros-tf的使用、slam使用、机器人自主导航,我先简单发出来,等我整理完再重新编辑一边。...

彩灯控制器设计 74ls160+ne555实现
一、选题背景 数字电子技术在我们生活中的应用非常之广泛,不论是在各个方面都会涉及到它,小到家用电器的自动控制,大到神舟九号和天空一号航天器的设计,都无可避免的要运用它。并且鉴于以理论推动实践及理论实践相结合为指导思想,特此用我们所学的理论知识来实践这次课程设…...
Windows API 速查
Windows API 函数大全 (推荐):https://blog.csdn.net/xiao_yi_xiao/article/details/121604742Windows API 在线参考手册:http://www.office-cn.net/t/api/index.html?web.htmWindows 开发文档 (官方):https://learn.microsoft.com/zh-cn/wi…...

智能名片小程序源码系统平台版 人人可创建属于自己的名片 前后端分离 带完整的源代码以及搭建教程
系统概述 智能名片小程序源码系统平台版是一款基于微信小程序的个性化名片搭建平台。该平台采用前后端分离的设计架构,前端提供丰富的界面元素和灵活的布局方式,后端则提供强大的数据支持和功能扩展能力。用户无需具备专业的编程知识,只需按…...

香橙派OrangePI AiPro测评 【运行qt,编解码,xfreeRDP】
实物 为AI而生 打开盒子 配置 扛把子的 作为业界首款基于昇腾深度研发的AI开发板,Orange Pi AIpro无论在外观上、性能上还是技术服务支持上都非常优秀。采用昇腾AI技术路线,集成图形处理器,拥有8GB/16GB LPDDR4X,可以外接32…...

重生之我要精通JAVA--第七周笔记
文章目录 IO流字符流字符流原理解析flush和close方法 文件拷贝代码文件加密解密修改文件中的数据 缓冲流字节缓冲流字符缓冲流例题 转换流序列化流序列化流/对象操作输出流 反序列化流序列化流/反序列化流的细节汇总打印流字节打印流字符打印流 解压缩流压缩流Commons-io常见方…...

MySQL—函数—数值函数(基础)
一、引言 首先了解一下常见的数值函数哪些?并且直到它们的作用,并且演示这些函数的使用。 二、数值函数 常见的数值函数如下: 注意: 1、ceil(x)、floor(x) :向上、向下取整。 2、mod(x,y):模运算&#x…...

fintuning chatglm3
chatglm3介绍 ChatGLM3-6B 是 ChatGLM 系列最新一代的开源模型,在保留了前两代模型对话流畅、部署门槛低等众多优秀特性的基础上,ChatGLM3-6B 引入了如下特性: 更强大的基础模型: ChatGLM3-6B 的基础模型 ChatGLM3-6B-Base 采用…...
草台班子啊草台班子:共享电源导致的BUG(供电不足)
某日吧(其实就是今日,不过什么时候我又删帖重发也不一定啊),下工厂干活,机器里面没多的插座(其实一个插座都没有,但是有一个24V电源的的设备),于是带队的下令并着接&…...
java递归计算文件夹和文件大小
背景 背景发现电脑c盘占用过高,然而我却不清楚是哪些文件占用了磁盘空间,于是我希望用程序来帮我完成这件事。小插曲:开始的时候,我使用python来做的,结果发现效率实在是太低,最后用java重写了一波。有需要的同学可以拿去修改一些。 代码 import java.io.File; import ja…...

硬币检测电路设计
一、来源:凡亿教育 第一场:硬币检测装置原理分析、电路设计以及器件选型_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1Zh4y1V7Px/?p1&vd_source43eb1cb50ad3175d7f3b9385905cd88f 二、开发软件:KEIL MDK 三、主控芯片&#…...

3.基础光照
从宏观上讲渲染包含了两大部分:决定一个像素的可见性,决定一个像素的光照计算 而光照模型就是用于决定在一个像素上决定怎样的渲染光照计算。 一、我们是如何看到这个世界的 1.光源 实时渲染中,我们通常把光源当成一个没有体积的点&#…...

Image Search-这是你的图像搜索
Image Search-这是你的图像搜索 什么是图像搜索图像搜索开通图像搜索商品图片搜索图片搜索图片新增批量操作OSS-创建bucket上传文件创建increment.meta并上传元信息导出 体验感受 什么是图像搜索 在接触一个新的产品时,我们首先要知道这款产品是什么?那…...
对GPT-4o的评价:技术革新与未来展望
目录 引言一、GPT-4o的技术背景1.1 GPT系列的发展历程1.2 GPT-4o的技术特点 二、版本间的对比分析2.1 GPT-3与GPT-4的对比2.2 GPT-4与GPT-4o的对比 三、GPT-4o的技术能力3.1 自然语言处理3.2 多模态处理3.3 任务定制化 四、个人整体感受4.1 交互体验4.2 应用场景4.3 未来展望 五…...
【TB作品】msp430f5529单片机,dht22,烟雾传感器
功能 //硬件:msp430f5529、dht22、LCD1602、蜂鸣器、烟雾传感器、蓝牙模块。 //功能:读取温湿度、烟雾浓度显示到屏幕; //按键调节三个报警数值; //温度、湿度、烟雾浓度,任意一个大于报警数值就蜂鸣器报警࿱…...

uni-app全局弹窗的实现方案
背景 为了解决uni-app 任意位置出现弹窗 解决方案 一、最初方案 受限于uni-app 调用组件需要每个页面都引入注册才可以使用,此方案繁琐,每个页面都要写侵入性比较强 二、改进方案 app端:新建一个页面进行跳转,可以实现伪弹窗…...

Love-Yi情侣网站3.0存在SQL注入漏洞
目录 1. 前言 2. 网站简介 3. 寻找特征点 3.1 第一次尝试 3.2 第二次尝试 4.资产搜索 5.漏洞复现 5.1 寻找漏洞点 5.2 进行进一步测试 5.2.1 手动测试 1.寻找字段 2.寻找回显位 3.查询当前用户 5.2.2 sqlmap去跑 6.总结 1. 前言 朋友说自己建了一个情侣网站,看到…...

自然语言处理(NLP)—— 神经网络语言处理
1. 总体原则 1.1 深度神经网络(Deep Neural Network)的训练过程 下图展示了自然语言处理(NLP)领域内使用的深度神经网络(Deep Neural Network)的训练过程的简化图。 在神经网络的NLP领域: 语料…...
挑战杯推荐项目
“人工智能”创意赛 - 智能艺术创作助手:借助大模型技术,开发能根据用户输入的主题、风格等要求,生成绘画、音乐、文学作品等多种形式艺术创作灵感或初稿的应用,帮助艺术家和创意爱好者激发创意、提高创作效率。 - 个性化梦境…...

深入剖析AI大模型:大模型时代的 Prompt 工程全解析
今天聊的内容,我认为是AI开发里面非常重要的内容。它在AI开发里无处不在,当你对 AI 助手说 "用李白的风格写一首关于人工智能的诗",或者让翻译模型 "将这段合同翻译成商务日语" 时,输入的这句话就是 Prompt。…...
在HarmonyOS ArkTS ArkUI-X 5.0及以上版本中,手势开发全攻略:
在 HarmonyOS 应用开发中,手势交互是连接用户与设备的核心纽带。ArkTS 框架提供了丰富的手势处理能力,既支持点击、长按、拖拽等基础单一手势的精细控制,也能通过多种绑定策略解决父子组件的手势竞争问题。本文将结合官方开发文档,…...

如何将联系人从 iPhone 转移到 Android
从 iPhone 换到 Android 手机时,你可能需要保留重要的数据,例如通讯录。好在,将通讯录从 iPhone 转移到 Android 手机非常简单,你可以从本文中学习 6 种可靠的方法,确保随时保持连接,不错过任何信息。 第 1…...
css3笔记 (1) 自用
outline: none 用于移除元素获得焦点时默认的轮廓线 broder:0 用于移除边框 font-size:0 用于设置字体不显示 list-style: none 消除<li> 标签默认样式 margin: xx auto 版心居中 width:100% 通栏 vertical-align 作用于行内元素 / 表格单元格ÿ…...
Element Plus 表单(el-form)中关于正整数输入的校验规则
目录 1 单个正整数输入1.1 模板1.2 校验规则 2 两个正整数输入(联动)2.1 模板2.2 校验规则2.3 CSS 1 单个正整数输入 1.1 模板 <el-formref"formRef":model"formData":rules"formRules"label-width"150px"…...

算法岗面试经验分享-大模型篇
文章目录 A 基础语言模型A.1 TransformerA.2 Bert B 大语言模型结构B.1 GPTB.2 LLamaB.3 ChatGLMB.4 Qwen C 大语言模型微调C.1 Fine-tuningC.2 Adapter-tuningC.3 Prefix-tuningC.4 P-tuningC.5 LoRA A 基础语言模型 A.1 Transformer (1)资源 论文&a…...
JS设计模式(4):观察者模式
JS设计模式(4):观察者模式 一、引入 在开发中,我们经常会遇到这样的场景:一个对象的状态变化需要自动通知其他对象,比如: 电商平台中,商品库存变化时需要通知所有订阅该商品的用户;新闻网站中࿰…...
PAN/FPN
import torch import torch.nn as nn import torch.nn.functional as F import mathclass LowResQueryHighResKVAttention(nn.Module):"""方案 1: 低分辨率特征 (Query) 查询高分辨率特征 (Key, Value).输出分辨率与低分辨率输入相同。"""def __…...

GruntJS-前端自动化任务运行器从入门到实战
Grunt 完全指南:从入门到实战 一、Grunt 是什么? Grunt是一个基于 Node.js 的前端自动化任务运行器,主要用于自动化执行项目开发中重复性高的任务,例如文件压缩、代码编译、语法检查、单元测试、文件合并等。通过配置简洁的任务…...