百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Mysql Binlog

wptr33 2024-11-19 12:24 13 浏览

目录


Binlog日志介绍

Binlog的记录模式

Binlog的文件结构

Binlog的写入机制

Binlog 文件操作

binlog状态查看 & 开启binlog功能

使用mysq lbinlog恢复数据

删除binlog


Binlog日志介绍

二进制log,别于数据库引擎的redo log。

binlog记录记录DML DDL 。

Binlog的记录模式

?

statement 有点像redis的 rdb持久化。

Binlog的文件结构

?


?

这个log的格式了解即可,查看log时再来查询。

Binlog的写入机制

?

Binlog 文件操作

如何做到删库而不跑路..............

binlog状态查看 & 开启binlog功能

windows 的mysql配置文件是my.ini .

linux下的mysql配置文件是 my.cnf。

?

查看binlog是否开启、binlog目录、

Bash
mysql> show variables like '%log_bin%'
    -> ;
+---------------------------------+--------------------------------+
| Variable_name                   | Value                          |
+---------------------------------+--------------------------------+
| log_bin                         | ON                             |
| log_bin_basename                | /var/lib/mysql/mysql-bin       |
| log_bin_index                   | /var/lib/mysql/mysql-bin.index |
| log_bin_trust_function_creators | OFF                            |
| log_bin_use_v1_row_events       | OFF                            |
| sql_log_bin                     | ON                             |
+---------------------------------+--------------------------------+
6 rows in set (0.00 sec)

查看binlog命令

?

Bash
mysql> show binary logs;
+------------------+------------+
| Log_name         | File_size  |
+------------------+------------+
| mysql-bin.000343 | 1073742436 |
| mysql-bin.000344 | 1073829002 |
| mysql-bin.000345 | 1073742690 |
| mysql-bin.000346 | 1073747797 |
| mysql-bin.000347 | 1073742425 |
| mysql-bin.000348 | 1073755538 |
| mysql-bin.000349 |  326803210 |
+------------------+------------+
7 rows in set (0.00 sec)

mysql> show master logs;
+------------------+------------+
| Log_name         | File_size  |
+------------------+------------+
| mysql-bin.000343 | 1073742436 |
| mysql-bin.000344 | 1073829002 |
| mysql-bin.000345 | 1073742690 |
| mysql-bin.000346 | 1073747797 |
| mysql-bin.000347 | 1073742425 |
| mysql-bin.000348 | 1073755538 |
| mysql-bin.000349 |  326804487 |
+------------------+------------+
7 rows in set (0.00 sec)


使用mysq lbinlog恢复数据

使用mysqlbinlog 把sql文本dump出来直接用编辑器打开。

?

 ~]# locate mysql-bin.000348
/var/lib/mysql/mysql-bin.000348
 ~]# mysqlbinlog /var/lib/mysql/mysql-bin.000348 > /opt/0103.sql
 ~]# ll /opt/ |grep 0103
-rw-r--r--  1 root   root     1296229905 Jan  3 00:34 0103.sql
 ~]# ll -ths /opt/ |grep 0103
1.3G -rw-r--r--  1 root   root     1.3G Jan  3 00:34 0103.sql

默认大小是1.3G.


?

删库了,该跑路了。不用,冷静思考不要慌。

先确认一下binlog在不在,现存哪些日志。

1、show master logs;

查看binlog内容

2、show binlog events in '';

红色框的位置就是恢复的开始和结束位置。

?

?

3、使用mysqlbinlog恢复

mysqlbinlog

?

?

mysqldump: 定期全部备份数据库,mysqlbinlog可以做增量备份和数据恢复

删除binlog

?

binlog超过几天自动删除:

mysql> show variables like '%expire_logs%'
    -> ;
+------------------+-------+
| Variable_name    | Value |
+------------------+-------+
| expire_logs_days | 7     |
+------------------+-------+

相关推荐

如何使用git clone克隆包含子模块的仓库

技术背景在软件开发中,当项目规模逐渐增大时,为了更好地管理代码,我们常常会使用子模块将项目拆分成多个独立的部分。Git作为目前最流行的版本控制系统,提供了管理子模块的功能。但在克隆包含子模块的仓库时...

基于Docker构建安装Git/GitLab,以及制作springboot工程镜像

今天给大家分享的是《领先的开源自动化服务器Jenkins的应用实战》之基于Docker安装构建Git/GitLab版本控制与代码云存储的场所;使用Git管理项目,springboot工程制作镜像知识体...

Windows误删急救!3步找回+防删秘籍,免费工具一键恢复

“Shift+Delete一时爽,数据火葬场?”误删工作文档、清空珍贵照片、手滑格式化硬盘……这份Windows专属“后悔药”攻略,从...

Git分支创建与合并

首先,我们创建dev分支,然后切换到dev分支:12$gitcheckout-bdev...

Java项目版本控制的最佳实践

Java项目版本控制的最佳实践在Java开发的世界里,版本控制是构建高效协作和管理代码变更的基础。想象一下,如果没有版本控制,就像一群人在沙滩上画画,每个人都在修改别人的画作,很快就会变得混乱不堪。今...

10分钟搭建自己的Git仓库

10分钟搭建自己的Git仓库...

GIT,如何恢复修改过的文件,回到过去呢?

我们知道git系统有三个区域:工作目录、暂存区域和git仓库所以恢复修改过的文件,需要考虑到三种情况。第一种情况,修改了文件,之后就再也没有任何的git操作了。这种情况只需要将当前版本的暂存区的状态还...

打造企业级自动化漏洞修复系统结( GitOps + Trivy + Argo CD )

在当今DevSecOps流水线中,实现漏洞自动检测+自动修复+自动部署是关键环节。本指南将结合:...

如何搭建一个git服务器?

GitHub是一个免费托管开源代码的Git服务器,如果我们不想公开项目的源代码,又不想付费使用,那么我们可以自己搭建一台Git服务器。首先你需要一台client和一台server。client可以是w...

Python进阶-day27: 版本控制与协作

1.学习Git基本命令Git是一个强大的分布式版本控制系统,用于跟踪代码更改和团队协作。以下是课程要求的四个基本命令的说明和使用方法:(1)gitclone作用...

git 基础分支管理基础操作

两个仓库git有两个仓库,一个本地仓库,一个远端仓库。大部分开发工作都是在本地仓库完成,程序没有问题后提交到远端仓库。一般是多用户维护一个git仓库...

Git新手入门

欢迎各位准开发者与技术爱好者!如果你曾好奇专业开发者如何协作大型项目而不丢失修改记录(更不用说覆盖他人代码),那么你来对地方了。答案就是Git——已成为开发者工具库中不可或缺的利器。这份详尽指...

Git推送错误:failed to push some refs to 'git@gitee.com:XXX'

项目推送时遇Git推送错误:error:failedtopushsomerefsto‘git@gitee.com:name/project.git’...

常用git命令-从远程更新代码合并分支、提交代码等

gitconfig设置gitconfiguser.name""...

迁移GIT仓库并带有历史提交记录

迁移git仓库开发在很多时候,会遇到一个问题。GIT仓库的管理,特别是仓库的迁移。我需要保留已有的历史记录,而不是重新开发,重头再来。...