Linux常见文件系统类型:ext3(CentOS5),ext4(CentOS6),xfs(CentOS7)

Windows常见文件系统类型:FAT32,NTFS

(1).inode的内容

1)inode包含文件的元信息,具体来说有以下内容:

文件的字节数

文件拥有者的User ID

文件的Group ID

文件的读、写、执行权限

文件的时间戳,共有三个:ctime指inode上次文件属性变动的时间,例如:chmod +x a.sh;mtime指文件内容上次变动的时间,例如:echo aa >> a.sh或vim a.sh;atime值文件上次打开的时间,例如:cat a.sh。

链接数,即有多少文件名指向这个inode

文件数据block的位置

2)我们可以用stat命令,查看某个文件的inode信息:

[root@xuexi ~]# stat /etc/passwd
文件:"/etc/passwd"
大小:2257 块:8 IO 块:4096 普通文件
设备:803h/2051d Inode:17324457 硬链接:1
权限:(0644/-rw-r--r--) Uid:( 0/ root) Gid:( 0/ root)
环境:system_u:object_r:passwd_file_t:s0
最近访问:2019-03-08 11:00:01.672759577 +0800
最近更改:2019-02-13 16:19:23.303395879 +0800
最近改动:2019-02-13 16:19:23.305395782 +0800
创建时间:-
[root@xuexi ~]# echo $LANG //查看当前语言
zh_CN.UTF-8
[root@xuexi ~]# LANG="en_US.UTF-8" //语言临时转为英文
[root@xuexi ~]# stat /etc/passwd
File: ‘/etc/passwd’
Size: 2257 Blocks: 8 IO Block: 4096 regular file
Device: 803h/2051d Inode: 17324457 Links: 1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Context: system_u:object_r:passwd_file_t:s0
Access: 2019-03-08 11:00:01.672759577 +0800
Modify: 2019-02-13 16:19:23.303395879 +0800
Change: 2019-02-13 16:19:23.305395782 +0800
Birth: -
[root@xuexi ~]# ll /etc/passwd //ll其实就是查看文件的inode信息
-rw-r--r--. 1 root root 2257 Feb 13 16:19 /etc/passwd //ll查看到的时间是ctime时间

3)测试ctime,mtime和atime

[root@xuexi ~]# touch a.txt
[root@xuexi ~]# stat a.txt
File: ‘a.txt’
Size: 0 Blocks: 0 IO Block: 4096 regular empty file
Device: 803h/2051d Inode: 34042450 Links: 1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Context: unconfined_u:object_r:admin_home_t:s0
Access: 2019-03-08 14:24:17.272886924 +0800
Modify: 2019-03-08 14:24:17.272886924 +0800
Change: 2019-03-08 14:24:17.272886924 +0800
Birth: -
[root@xuexi ~]# date -s "2019-03-07 14:29:49" //修改系统时间
Thu Mar 7 14:29:49 CST 2019
[root@xuexi ~]# chmod +x a.txt
[root@xuexi ~]# stat a.txt //可以看到’ chmod +x a.txt’修改了ctime
File: ‘a.txt’
Size: 0 Blocks: 0 IO Block: 4096 regular empty file
Device: 803h/2051d Inode: 34042450 Links: 1
Access: (0755/-rwxr-xr-x) Uid: ( 0/ root) Gid: ( 0/ root)
Context: unconfined_u:object_r:admin_home_t:s0
Access: 2019-03-08 14:24:17.272886924 +0800
Modify: 2019-03-08 14:24:17.272886924 +0800
Change: 2019-03-07 14:30:32.246910417 +0800
Birth: -
[root@xuexi ~]# echo aa >> a.txt
[root@xuexi ~]# stat a.txt //可以看到’ echo aa >> a.txt’修改了mtime和ctime
File: ‘a.txt’
Size: 3 Blocks: 8 IO Block: 4096 regular file
Device: 803h/2051d Inode: 34042450 Links: 1
Access: (0755/-rwxr-xr-x) Uid: ( 0/ root) Gid: ( 0/ root)
Context: unconfined_u:object_r:admin_home_t:s0
Access: 2019-03-08 14:24:17.272886924 +0800
Modify: 2019-03-07 14:31:19.164728344 +0800
Change: 2019-03-07 14:31:19.164728344 +0800
Birth: -
[root@xuexi ~]# vim a.txt
//添加了一行bbb
[root@xuexi ~]# stat a.txt //可以看到’ vim a.txt’修改了atime,ctime和mtime
File: ‘a.txt’
Size: 7 Blocks: 8 IO Block: 4096 regular file
Device: 803h/2051d Inode: 34729170 Links: 1
Access: (0755/-rwxr-xr-x) Uid: ( 0/ root) Gid: ( 0/ root)
Context: unconfined_u:object_r:admin_home_t:s0
Access: 2019-03-07 14:32:42.604862498 +0800
Modify: 2019-03-07 14:32:42.604862498 +0800
Change: 2019-03-07 14:32:42.605945804 +0800
Birth: -
[root@xuexi ~]# cat a.txt
aa
bbb
[root@xuexi ~]# stat a.txt //可以看到’ cat a.txt’修改了atime
File: ‘a.txt’
Size: 7 Blocks: 8 IO Block: 4096 regular file
Device: 803h/2051d Inode: 34729170 Links: 1
Access: (0755/-rwxr-xr-x) Uid: ( 0/ root) Gid: ( 0/ root)
Context: unconfined_u:object_r:admin_home_t:s0
Access: 2019-03-07 14:34:27.525217232 +0800
Modify: 2019-03-07 14:32:42.604862498 +0800
Change: 2019-03-07 14:32:42.605945804 +0800
Birth: -

  由此可见,黑客是可以通过修改时间,再植入木马,防止被find找到。

4)inode的大小

Inode也会消耗硬盘空间,所以硬盘格式化时,操作系统自动将文件分成两个区域。一个是数据区,用于存放文件数据;另一个是inode区,用于存放inode所包含的信息。

每个inode节点的大小一般是128字节或256字节。Inode节点的总数在格式化时就给定,一般是1KB或2KB或4KB就设置一个inode。如果一块1GB的硬盘,每个inode节点的大小为128字节,每1KB就设置一个inode,那么inode区的大小就会达到128MB,占整个硬盘的12.8%。(所以block可以设置的大一点)

5)inode号

每个inode都有一个号码,操作系统用inode号来识别不同的文件。

Unix/Linux系统内部不是用文件名,而使用inode号来识别文件。对于系统来说,文件名只是iode号便于识别的别名。表面上用户是通过文件名打开文件,实际上系统内部分成三个步骤:首先,系统找到这个文件名对应的inode号;其次通过inode号获取inode信息;最后根据inode信息找到文件数据所在的block,读出数据。

可以使用’ls -i [filename]’快速查看文件的inode号:

[root@xuexi ~]# ls -i a.txt
34729170 a.txt

  在Unix/Liunx系统中,目录也是一种文件。目录文件的结构非常简单,即使一系列目录项的列表。每个目录项由所包含文件的文件名以及该文件名对应的inode号组成。

  可以使用’ls -id [directory]’快速查看目录的inode号:

[root@xuexi ~]# ls -id /etc
16777281 /etc

  另外可以使用’df -i’查看每个磁盘分区的inode总数和已经使用的数量

[root@xuexi ~]# df -i
文件系统 Inode 已用(I) 可用(I) 已用(I)% 挂载点
/dev/sda3 8912384 193509 8718875 3% /
devtmpfs 249583 408 249175 1% /dev
tmpfs 253514 1 253513 1% /dev/shm
tmpfs 253514 966 252548 1% /run
tmpfs 253514 16 253498 1% /sys/fs/cgroup
/dev/sda1 524288 359 523929 1% /boot
/dev/sr0 0 0 0 - /mnt
tmpfs 253514 6 253508 1% /run/user/42
tmpfs 253514 17 253497 1% /run/user/1000
tmpfs 253514 1 253513 1% /run/user/0

  注意:由于每个文件都必须有一个inode号,因此有可能发生inode已用光,但硬盘未存满的情况。这时就无法在硬盘上创建新的文件。

6)inode的特殊作用

  有时文件名有特殊字符或乱码,无法正常修改或删除,可以通过inode号来进行操作。实例:

[xf@xuexi ~]$ mkdir Dir
[xf@xuexi ~]$ cd Dir/
[xf@xuexi Dir]$ touch 学习  \\创建一个中文的文件名
[xf@xuexi Dir]$ ls
学习
[xf@xuexi Dir]$ LANG="en_US.gbk"  \\临时调整一下编码,使得文件名变为乱码
[xf@xuexi Dir]$ ls
??????
[xf@xuexi Dir]$ ls -i  \\看一下该文件的inode号
407062 ??????
\\删除还可以使用"find . -inum 407062 -delete"(没有提示)以及"find . -inum 407062 | xargs -i rm {}"
\\修改类似
[xf@xuexi Dir]$ find . -inum 407062 -exec rm -i {} \;
rm: remove regular empty file './\345\255\246\344\271\240'? y
[xf@xuexi Dir]$ ls

  移动或重命名文件,只改变文件名,inode没影响。

  使用vim修改文件内容后,inode会发生改变。实例:

[xf@xuexi ~]$ touch File
[xf@xuexi ~]$ ls -i File
52016344 File
[xf@xuexi ~]$ vim File
//增加一行aaaaa
[xf@xuexi ~]$ ls -i File  //inode号改变了
52016202 File
[xf@xuexi ~]$ echo bbbbb>>File  //追加一行bbbbb
[xf@xuexi ~]$ ls -i File  //inode号没变
52016202 File
[xf@xuexi ~]$ cat File
aaaaa
bbbbb
[xf@xuexi ~]$ ls -i File
52016202 File
[xf@xuexi ~]$ cat > File <<EOF  //重写File
> ccccc
> ddddd
> EOF
[xf@xuexi ~]$ ls -i File  //inode号还是没变
52016202 File

  我一开始还怀疑会不会是我字节没有写满一个block,但我用cat写了20416个字节,结果inode号还是没变。我估计echo追加和cat重写都不改变inode号。

(2).block的内容

block是真正存储数据的地方。block是文件系统中的最小存储单位,扇区是磁盘中的最小存储单位。

注意:Linux下叫block,Windows下叫簇。

1)  Windows如何修改簇的大小

  可以右键一个分区,点击格式化会出现如下窗口:

这里的分配单元大小就是设置簇的大小。

2)  Block或簇的大小对系统的影响

  簇或block调大时,节约了寻址时间,速度变快,但浪费空间;簇和block调小时,节约空间,但寻址时间变长,速度变慢。

  说明:为什么簇或block调大会浪费空间?这是因为一个文件会占用多个簇或block来存放。当前一个簇或block放不下时,就会占用下一个簇或block,到最后如果产生不足以占用一个完整的簇或block时,仍然会占用一个完整的簇或block,就会浪费这个簇或block剩下的空间。

如果有一个2T的硬盘,可以前1.5T使用4K的簇或block,后0.5G使用64K的簇或block,这样可以改善机械硬盘越到最后速度越慢的问题。

3)  Linux下查看block的大小以及修改方式

  查看block的大小

[root@xuexi ~]# file -s /dev/sdb1	//把block或设备当做普通文件看待
/dev/sdb1: SGI XFS filesystem data (blksz 4096, inosz 512, v2 dirs)
[root@xuexi ~]# xfs_info /dev/sdb1
xfs_info: /dev/sdb1 is not a mounted XFS filesystem //居然需要先挂载
[root@xuexi ~]# ls /
bin dev etc lib media opt root sbin srv tmp var
boot dump home lib64 mnt proc run sdb1 sys usr
[root@xuexi ~]# mkdir /sdb1
mkdir: 无法创建目录"/sdb1": 文件已存在
[root@xuexi ~]# mount /sdb1 /dev/sdb1
mount: /sdb1 不是一个块设备
[root@xuexi ~]# mount /dev/sdb1 /sdb1/
[root@xuexi ~]# xfs_info /dev/sdb1
meta-data=/dev/sdb1 isize=512 agcount=4, agsize=65536 blks
= sectsz=512 attr=2, projid32bit=1
= crc=1 finobt=0 spinodes=0
data = bsize=4096 blocks=262144, imaxpct=25
= sunit=0 swidth=0 blks
naming =version 2 bsize=4096 ascii-ci=0 ftype=1
log =internal bsize=4096 blocks=2560, version=2
= sectsz=512 sunit=0 blks, lazy-count=1
realtime =none extsz=4096 blocks=0, rtextents=0

  注意:xfs_info只能用于xfs的文件系统,如果是ext4或ext3请使用tune2fs

  修改block的大小,就需要用到mkfs.xfs格式化命令,需要格式化分区

[root@xuexi ~]# umount /sdb1
[root@xuexi ~]# mkfs -t xfs -b size=2048 /dev/sdb1
mkfs.xfs: /dev/sdb1 appears to contain an existing filesystem (xfs).
mkfs.xfs: Use the -f option to force overwrite.
[root@xuexi ~]# mkfs -t xfs -b size=2048 -f /dev/sdb1
meta-data=/dev/sdb1 isize=512 agcount=4, agsize=131072 blks
= sectsz=512 attr=2, projid32bit=1
= crc=1 finobt=0, sparse=0
data = bsize=2048 blocks=524288, imaxpct=25
= sunit=0 swidth=0 blks
naming =version 2 bsize=4096 ascii-ci=0 ftype=1
log =internal log bsize=2048 blocks=5120, version=2
= sectsz=512 sunit=0 blks, lazy-count=1
realtime =none extsz=4096 blocks=0, rtextents=0

  注意:mkfs.xfs就是mkfs –t xfs的简写。

简单了解Linux的inode与block的更多相关文章

  1. Linux系统——inode和block

    Linux文件属性 磁盘被分区并格式化为ext4文件系统后,会生成一定数量的inode和block Inode 索引节点 作用:存放文件的属性信息以及作为文件的索引(指向文件的实体block) Blo ...

  2. Linux文件系统inode、block解释权限(三)

    利用文件系统的inode和block来分析文件(目录)的权限问题. 为什么读取一个文件还要看该文件路径所有目录的权限? 为什么目录的w权限具有删除文件的能力,而文件w权限不行. inode:记录文件的 ...

  3. Linux的inode与block

    1,inode包含文件的元信息,具体来说有以下内容: 文件的字节数 文件拥有者的User ID 文件的Group ID 文件的读.写.执行权限 文件的时间戳,共有三个:ctime指inode上次文件属 ...

  4. Centos的Inode及Block相关知识

    Centos的Inode及Block相关知识 时间:2016-06-04 01:54来源:blog.51cto.com 作者:"tao" 博客 举报 点击:173次 本经验均在Ce ...

  5. Linux文件系统与inode、Block笔记

    Linux文件系统与inode.Block笔记 在Linux下一切都是文件,无论是设备还是接口,亦或是网卡等均被抽象成了文件,并且有相关的内核代码进行调度.然而,在一切都是文件的前提下,最需要进行探讨 ...

  6. Linux文件系统(inode、block……)

    内容源于<鸟哥的Linux私房菜> 认识 EXT2 文件系统 文件系统的特殊观察与操作 文件系统 superblock,inode,block superblock,inode,block ...

  7. linux 文件系统(inode和block)

    linux文件系统(inode block superblock)   先说一下格式化:每种操作系统所设置的文件属性/权限并不相同,为了存放这些文件所需的数据,因此就需要将分区格式化,以成为操作系统能 ...

  8. # linux文件系统(inode block superblock)

    先说一下格式化:每种操作系统所设置的文件属性/权限并不相同,为了存放这些文件所需的数据,因此就需要将分区格式化,以成为操作系统能够利用的文件系统格式.linux的文件格式为Ext2/Ext3,现在好像 ...

  9. Linux文件访问流程及磁盘inode和block总结

    Linux文件访问流程 inode是文件的唯一标识,文件名和inode的对应关系存放在上一级目录的block中:inode里有指向文件block的指针和文件的属性,从而通过block获得文件数据. 磁 ...

随机推荐

  1. HDU 5145 分块 莫队

    给定n个数,q个询问[l,r]区间,每次询问该区间的全排列多少种. 数值都是30000规模 首先考虑计算全排列,由于有同种元素存在,相当于每次在len=r-l+1长度的空格随意放入某种元素即$\bin ...

  2. JVM调优总结(2):基本垃圾回收算法

    可以从不同的的角度去划分垃圾回收算法: 按照基本回收策略分 引用计数(Reference Counting): 比较古老的回收算法.原理是此对象有一个引用,即增加一个计数,删除一个引用则减少一个计数. ...

  3. 重构改善既有代码设计--重构手法14:Hide Delegate (隐藏委托关系)

    客户通过一个委托类来调用另一个对象.在服务类上建立客户所需的所有函数,用以隐藏委托关系. 动机:封装即使不是对象的最关机特性,也是最关机特性之一.“封装”意味着每个对象都应该少了解系统的其他部分.如此 ...

  4. 10个基于 JavaScript 的 WYSIWYG 编辑器

    COMSHARP CMS 写道:在线编辑内容的时候,那些基于 JavaScript 的编辑器帮了我们大忙,这些所见即所得(WYSIWYG)编辑器,给我们提供了类似 Office 的操作体验.如今,任何 ...

  5. TreeSet的特性

    TreeSet在Set的元素不重复的基础之上引入排序的概念,其中对自身拥有Comparable的元素,可以直接进行排序,比如字符串,按照字母的自然顺序排序,此处说下对于自定义对象排序的方式. 1.存储 ...

  6. sql统计字符串出现次数技巧

    在牛客网上看到一道题,感觉挺有趣,是用sql统计字符串出现的次数. 这里提供一种思路,比如统计字符串A中子串B的出现次数: SELECT (LENGTH(A) - LENGTH(REPLACE(A, ...

  7. Gym 101081K Pope's work

    题目链接:Gym - 101081K 题意:给n个箱子,每个箱子有一个重量W和一个承重R,表示它上面能放最多R-W的重量.问最多能把多少箱子堆到一堆. 思路:发现在一堆箱子里,两个箱子交换位置,对其他 ...

  8. 10.python3标准库--加密

    ''' 加密可以保护消息安全,以便验证其正确性并保护消息不被截获. python的加密支持包括hashlib和hmac,hashlib使用标准算法生成消息内容签名,hmac则用于验证消息在传输过程中未 ...

  9. Linux阵列 RAID详解 (转)

    原文链接:http://molinux.blog.51cto.com/2536040/516008   一. RAID详解   二. mdadm工具介绍   三. 创建一个RAID的基本过程   四. ...

  10. List基本用法

    List最为Collection接口的子接口,当然可以使用Collection接口里的全部方法.而且由于List是有序集合,因此List集合里增加了一些根据索引来操作集合元素的方法: public c ...