MySQL删除idb文件引发的思考

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

  最近发现一个好玩的东西,就是通过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://aklaus.blog.51cto.com/9724632/1757817

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



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

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
存储 SQL 关系型数据库
MySQL 系统文件你了解吗
MySQL 系统文件你了解吗
37 0
|
4月前
|
存储 关系型数据库 MySQL
Linux的dev/vda1文件满了导致MySQL无法写入
今天查看两个月前上线的小项目,发现运行非常慢,而且增删改查失效了(吓我一大跳),急急忙忙的就开始了我的线上问题排查之路。/dev/vda1是 Linux 系统中的一个设备文件,它表示第一个虚拟磁盘(vda)的第一个分区(1)。在大多数 Linux 发行版中,这是系统根分区的默认位置。如果您要对/dev/vda1进行操作(例如挂载、格式化、备份等),则需要具有足够的权限。一般来说,只有 root 用户或具有 sudo 权限的用户才能进行这些操作。当Linux的/dev/vda1。
130 0
|
30天前
Mybatis+mysql动态分页查询数据案例——配置映射文件(HouseDaoMapper.xml)
Mybatis+mysql动态分页查询数据案例——配置映射文件(HouseDaoMapper.xml)
15 1
|
3月前
|
关系型数据库 MySQL 数据库
csv文件导入mysql指定表中
csv文件导入mysql指定表中
|
4月前
|
存储 SQL 缓存
[MySQL] 二进制文件
[MySQL] 二进制文件
|
4月前
|
关系型数据库 MySQL 数据库
(简单成功版本)Mysql配置my.ini文件
(简单成功版本)Mysql配置my.ini文件
72 0
(简单成功版本)Mysql配置my.ini文件
|
4月前
|
SQL 关系型数据库 MySQL
MySQL【实践 02】MySQL迁移到PostgreSQL数据库的语法调整说明及脚本分享(通过bat命令修改mapper文件内的SQL语法)
MySQL【实践 02】MySQL迁移到PostgreSQL数据库的语法调整说明及脚本分享(通过bat命令修改mapper文件内的SQL语法)
107 0
|
4月前
|
关系型数据库 MySQL Linux
【有关mysql定时备份脚本文件】
【有关mysql定时备份脚本文件】
33 0
|
4月前
|
XML 关系型数据库 MySQL
【Mysql】有关数据库中一对多/一对一,多对一xml中文件映射问题
【Mysql】有关数据库中一对多/一对一,多对一xml中文件映射问题
26 0
|
4月前
|
存储 SQL 关系型数据库
MySQL之深入InnoDB存储引擎——物理文件
一、参数文件 当 MySQL 实例启动时,数据库会先去读一个配置参数文件,用来寻找数据库的各种文件所在位置以及指定某些初始化参数。在默认情况下,MySQL 实例会按照一定的顺序在指定的位置读取,没有参数文件也可以运行,这时所有的参数值取决于编译 MySQL 时指定的默认值和源代码中指定参数的默认值。 但是如果在默认的数据库目录下找不到 mysql 架构,则启动同样失败,mysql 架构中记录了访问该实例的权限。