博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL删除idb文件引发的思考
阅读量:6241 次
发布时间:2019-06-22

本文共 726 字,大约阅读时间需要 2 分钟。

  最近发现一个好玩的东西,就是通过rm删除MySQL一个表的idb文件,发现我查这张表的时候数据还是可以查的,好奇怪怎么可以这样????

1
发现几个概念:文件系统与硬盘存储、inode节点、硬盘结构、Linux如何访问文件、lsof

通过查找资料发现:文件物理存储结构就是/home/stu01 /home/stu02 首先硬盘创建的时候会创建两个L东西一个存储真正的数据、一个存储一个inode表;当我们用cat查看一个文件的时候、Kernel会读取物理与inode表对应的该条信息,然后告诉Kernel根据inode里的信息读取硬盘上的真正数据。

从网上找了一个说明硬盘的东东:文件系统将硬盘划分为块,编号从0开始到整个磁盘的最大块数。

1
2
3
0块给引导块
1块成为专用块
从第二块开始是i节点表,表的块数是可变的i节点之后是空闲的存储块(真正存放数据的块)

  Linux某个地方会存放一个表(据说这个表又分成了13块号,到了11块号后每一个块号又可以产生256块号),告诉文件系统如何将物理结构转换成逻辑结果,这个逻辑结果就是i节点,i节点是一个64字节长的表,包含了有关一个文件的信息,包括文件大小,文件所有者,文件存取方式,类型等。

所以硬盘划分的时候一部分给了Block(真正存放文件数据的地方),还有一部分就是存放inode的东西,一般情况下inode的数量为硬盘大小/一个容量即(Block)。

du与df区别:

参考:http://my.oschina.net/sharelinux/blog/143816

本文转自 aklaus 51CTO博客,原文链接:http://blog.51cto.com/aklaus/1786165

转载地址:http://ubcia.baihongyu.com/

你可能感兴趣的文章
Unity 5 中的全局光照技术详解(建议收藏)
查看>>
python 的矩阵运算——numpy
查看>>
处理handler中的内存泄漏
查看>>
P8 Visible Lattice Points
查看>>
小小不爽一下
查看>>
【转】NuGet学习笔记(1)——初识NuGet及快速安装使用
查看>>
Python学习笔记 - MySql的使用
查看>>
WebApi FormData+文件长传 异步+同步实现
查看>>
Linux文件与目录管理
查看>>
多态的弊端
查看>>
Spring @Import 注解
查看>>
PBOC APDU命令解析【转】
查看>>
封装HttpUrlConnection开箱即用
查看>>
第二天笔记
查看>>
如何在外部终止一个pengding状态的promise对象
查看>>
初级模拟电路:1-5 二极管的其他特性
查看>>
《简明Python教程》Swaroop, C. H. 著 第1章 介绍
查看>>
Chapter 4. Working with Key/Value Pairs
查看>>
Python基础:Python可变对象和不可变对象
查看>>
[css3]文字过多以省略号显示
查看>>