系列教程--Linux基础--17--Linux 文件链接和inode详解

2024-05-15 16:32

本文主要是介绍系列教程--Linux基础--17--Linux 文件链接和inode详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本节概要

  inode详解

  软链接

  硬链接

环境准备

操作系统:Centos6.5、Centos7.2。

一、inode详解

1. inode大小

上节中我们提到inode中会存放除文件名之外的文件的各种元数据,既然inode需要存放数据则inode也会占用磁盘的存储空间,所以磁盘在格式化的时候操作系统会将磁盘分为两个区域,即数据区和inode区,其中数据区用于存放文件的数据,inode区用于存放inode所包含的信息。

每个inode 节点的一般占用空间为128字节或者256字节。

格式化磁盘的时候inode的总量就已经确定,一般1KB~2KB便会设置一个inode。那么一个1GB的硬盘假设一个inode节点为128字节,则inode table的大小约为128MB。

df –i查看各个分区inode的使用情况:

    

查看inode节点大小: dumpe2fs -h /dev/sdb1 | grep "Inode size"

      

2. inode编号

每个inode都有一个号码,linux 使用inode号码来识别不同的文件,而不是使用文件名识别文件,对于操作系统来说文件名只是inode的一个别名。

我们在操作文件时通过文件名进行操作,如打开文件的过程为:

(1) 系统找到文件名对应的inode号。

(2) 通过inode号获取inode信息。

(3) 根据inode信息找到文件数据所在的块(block),读取数据。

ls -i /etc/passwd 可以查看到文具文件的inode号:

3. 其他

(1) 移动文件或者重命名文件只是改变文件名并未改变文件的inode号码。

(2) 当文件名中包含特殊字符时无法对其进行删除,如因为中文乱码导致文件名也乱码的情况,此时可以通过ls –i 查看下文件的inode号码,然后使用inode进行删除文件。具体操作步骤如下:

[root@localhost ~]# ls -i      #查看inode,假设乱码的为file1

 71177312 anaconda-ks.cfg  102591184 Documents   68198336 file1    1492247 nginx-1.6.2          36291039 Pictures   34824185 Templates   70936513 zsh-5.0.2-28.el7.x86_64.rpm

102591182 Desktop             835472 Downloads    3128032 Music   68833699 nginx-1.6.2.tar.gz   67358509 Public     67358521 Videos

[root@localhost ~]# find . -inum 68198336 -exec rm -rf {} \;  #根据inode删除文件

[root@localhost ~]# ls

anaconda-ks.cfg  Desktop  Documents  Downloads  Music  nginx-1.6.2  nginx-1.6.2.tar.gz  Pictures  Public  Templates  Videos  zsh-5.0.2-28.el7.x86_64.rpm

(3) 打开一个文件后系统即以文件的inode来识别文件,不再使用文件名,也无法从inode中获取文件名,因为inode中未存储文件名。

利用这个原理在进行软件的更新的时候可以不关闭、重启软件,因为系统可以通过inode号码识别运行中的文件,不通过文件名,更新后的文件文件名相同但是inode不同,不影响正在运行中的文件,等下次运行这个文件的时候文件名便指向更新后的文件,旧文件的inode会被回收。

二、文件链接

文件链接分为硬链接和软链接。

1. 硬链接

可以以不同的文件名访问同样的内容,对一个文件内容的修改会影响到所有的文件名看到的文件内容,但是删除一个文件名不会影响到其他文件名的访问,这种即硬链接。

格式:ln 源文件  目标文件

举例:

文件硬链接:

硬链接,源文件和目标文件的inode相同:

文件连接数默认为1,新建硬链接后指向该inode的文件数由1变为2.

删除源文件不影响目标文件的内容,但是文件的链接数会减1:

当连接数减为0时文件会被删除。

目录硬链接:

创建一个目录,目录中默认会包含当前目录和父目录,因此新目录的硬链接数默认为2,目录的硬链接数目等于2加上目录中子目录总数,但不能对目录创建硬链接。

2. 软链接

软链接也叫符号链接,源文件和目标文件的inode不同,是两个不同的文件,目标文件中存放的是源文件的地址,访问目标文件时会自动将访问导向源文件。

软链接类似于windows系统中的快捷方式。

删除源文件会影响所有目标文件对数据的读取,此时读取目标文件会有异常提示,这是软链接和硬链接的最大区别。

示例:

格式:ln 参数 源文件  目标文件

参数: -s    软链接

3. 软硬链接比较

(1) 不能对目录创建硬链接。

可以对目录创建软链接。

(2) 硬链接不能跨文件系统(如源文件ext4,目标文件ext3),即源文件和目标文件需要在相同的文件系统内。

软链接可以跨文件系统。

(3) 不能对不存在的文件创建硬链接。

可以对不存在的文件创建软链接。

三、拓展

1. 自测软硬链接比较中的内容。

这篇关于系列教程--Linux基础--17--Linux 文件链接和inode详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/992339

相关文章

MySQL 8 中的一个强大功能 JSON_TABLE示例详解

《MySQL8中的一个强大功能JSON_TABLE示例详解》JSON_TABLE是MySQL8中引入的一个强大功能,它允许用户将JSON数据转换为关系表格式,从而可以更方便地在SQL查询中处理J... 目录基本语法示例示例查询解释应用场景不适用场景1. ‌jsON 数据结构过于复杂或动态变化‌2. ‌性能要

Python实现终端清屏的几种方式详解

《Python实现终端清屏的几种方式详解》在使用Python进行终端交互式编程时,我们经常需要清空当前终端屏幕的内容,本文为大家整理了几种常见的实现方法,有需要的小伙伴可以参考下... 目录方法一:使用 `os` 模块调用系统命令方法二:使用 `subprocess` 模块执行命令方法三:打印多个换行符模拟

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

Java中Arrays类和Collections类常用方法示例详解

《Java中Arrays类和Collections类常用方法示例详解》本文总结了Java中Arrays和Collections类的常用方法,涵盖数组填充、排序、搜索、复制、列表转换等操作,帮助开发者高... 目录Arrays.fill()相关用法Arrays.toString()Arrays.sort()A

Python 字典 (Dictionary)使用详解

《Python字典(Dictionary)使用详解》字典是python中最重要,最常用的数据结构之一,它提供了高效的键值对存储和查找能力,:本文主要介绍Python字典(Dictionary)... 目录字典1.基本特性2.创建字典3.访问元素4.修改字典5.删除元素6.字典遍历7.字典的高级特性默认字典

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

一文详解如何使用Java获取PDF页面信息

《一文详解如何使用Java获取PDF页面信息》了解PDF页面属性是我们在处理文档、内容提取、打印设置或页面重组等任务时不可或缺的一环,下面我们就来看看如何使用Java语言获取这些信息吧... 目录引言一、安装和引入PDF处理库引入依赖二、获取 PDF 页数三、获取页面尺寸(宽高)四、获取页面旋转角度五、判断

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更