第六章 存储结构与磁盘划分
6.1 一切从 "/ "开始
在Linux系统中,目录、字符设备、套接字、硬盘、光驱、打印机等都会被抽象成了文件形式,即“Linux系统中一切都是文件”;但是在Linux系统中并不存在C/D/E/F等盘符,Linux系统中的一切文件都是从“根(/)”目录开始的,并按照文件系统层次化标准(FHS:Filesystem Hierarchy Standard)采用倒树状结构来存放文件,以及定义了常见目录的用途;
Linux系统中的文件和目录名称是严格区分大小写的;
FHS只是一种规范,并非必须要遵循的;
Linux系统常见的目录名称及相应内容:
目录名称 | 应放置文件的内容 |
---|---|
/boot | ☆ 开机所需文件—内核、开机菜单以及所需配置文件等(驱动、引导文件) |
/dev | ☆ 以文件形式存放任何设备与接口(设备目录) |
/etc | ☆ 配置文件(保存系统及每个服务的配置文件) |
/home | 用户家目录(/home/用户名 单用户家目录的存放路径) |
/root | 系统管理员的家目录 |
/bin | 存放单用户模式下还可以操作的命令 |
/lib | 开机时用到的函数库,以及/bin与/sbin下面的命令要调用的函数 |
/sbin | 开机过程中需要的命令 |
/media | 用于挂载设备文件的目录(挂在光盘镜像、U盘 ;/mnt目录也可用于挂载) |
/srv | 一些网络服务的数据文件目录 |
/tmp | 任何人均可使用的“共享”临时目录(目录默认SBIT权限) |
/proc | 虚拟文件系统,例如系统内核、进程、外部设备及网络状态等(并非真实存在,而是把系统运行状态映射成文件的样子) |
/opt | 放置第三方的软件(和/usr/local类似,存放用户自装软件) |
/usr/local | 用户自行安装的软件(/usr目录用来存放用户自己的文件) |
/usr/sbin | Linux系统开机时不会使用到的软件/命令/脚本 |
/usr/share | 帮助与说明文件,也可放置共享文件(/usr/share/ansible放置ansible的帮助文件,考点) |
/var | 主要存放经常变化的文件,如日志、网站、数据库 |
/lost+found | 当文件系统发生错误时,将一些丢失的文件片段存放在这里(Ext3加入) |
PS:
所有带有bin的目录都是用来运放二进制可执行文件(命令文件)的;
当我们在配置一个服务时,实际就是在修改服务的配置文件。
绝对路径:注意linux的绝对路径是以根目录开始的
相对路径:
6.2 物理设备的命名规则
系统内核中的udev设备管理器会自动把硬件名称规范起来,目的是让用户通过设备文件的名字可以猜出设备大致的属性以及分区信息等;
udev设备管理器的服务会一直以守护进程的形式运行并侦听内核发出的信号来管理/dev目录下的设备文件。
常见的硬件设备及其文件名称:
硬件设备 | 文件名称 |
---|---|
IDE设备 | /dev/hd[a-d] |
☆ SCSI/SATA/U盘/ISCSI | /dev/sd[a-z] |
virtio设备(虚拟设备) | /dev/vd[a-z] |
软驱 | /dev/fd[0-1] |
打印机 | /dev/lp[0-15] |
☆ 光驱 | /dev/cdrom |
鼠标 | /dev/mouse |
磁带机 | /dev/st0或/dev/ht0 |
以 /dev/sd 设备为例,字母 a~z 代表着硬件的识别顺序,且后序若带数字,则代表不同分区:
- 主分区或扩展分区的编号从 1-4 ;
- 逻辑分区从编号 5 开始。
/dev/sda5
的正确理解:
/dev:设备目录下的
/sd:SCSI/SATA/U盘/ISCSI 设备
a:第一个被识别出来的此类设备(这个与物理设备插槽没有关系,只与识别顺序有关)
5:逻辑分区5
△ 扇区分区知识:
硬盘设备是由大量的扇区组成的,每个扇区的容量为512字节。其中第一个扇区最重要,它里面保存着主引导记录与分区表信息。就第一个扇区来讲,主引导记录需要占用446字节,分区表为64字节,结束符占用2字节;其中分区表中每记录一个分区信息就需要16字节,这样一来最多只有4个分区信息可以写到第一个扇区中,这4个分区就是4个主分区。
于是为了解决分区个数不够的问题,可以将第一个扇区的分区表中16字节(原本要写入主分区信息)的空间(称之为扩展分区)拿出来指向另外一个分区。也就是说,扩展分区其实并不是一个真正的分区,而更像是一个占用16字节分区表空间的指针—一个指向另外一个分区的指针。指向一个512字节的新扇区,新扇区里最多能扩展512/16=32个逻辑分区。
扩展分区并非一定是最后一个主分区,有可能1-4都是。
6.3 文件系统与数据资料
文件系统 | 调整 |
---|---|
Ext3 | 增加了/lost+found ,能回溯追踪到被中断的部分,然后尝试进行修复(RHEL5) |
Ext4 | 支持的存储容量高达1EB,且能有无限多的子目录;而且能批量分配block块,极大提高读写效率(RHEL6) |
XFS | 最大支持容量提高到了18EB(RHEL7、8) |
日常在硬盘中需要保存的数据实在太多了,因此Linux系统中有一个名为super block的“硬盘地图”。Linux并不是把文件内容直接写入到这个“硬盘地图”里面,而是在里面记录着整个文件系统的信息。因为如果把所有的文件内容都写入到这里面,它的体积将变得非常大,而且文件内容的查询与写入速度也会变得很慢。Linux只是把每个文件的权限与属性记录在inode中,而且每个文件占用一个独立的inode表格,该表格的大小默认为128字节,里面记录着如下信息:
该文件的访问权限(read、write、execute);
该文件的所有者与所属组(owner、group);
该文件的大小(size);
该文件的创建或内容修改时间(ctime);
该文件的最后一次访问时间(atime);
该文件的修改时间(mtime);
文件的特殊权限(SUID、SGID、SBIT);
该文件的真实数据地址(point)。而文件的实际内容则保存在block块中(大小可以是1KB、2KB或4KB),一个inode的默认大小仅为128字节,记录一个block则消耗4字节。当文件的inode被写满后,Linux系统会自动分配出一个block块,专门用于像inode那样记录其他block块的信息,这样把各个block块的内容串到一起,就能够让用户读到完整的文件内容了。对于存储文件内容的block块,有下面两种常见情况(以4KB的block大小为例进行说明)。
情况1:文件很小(1KB),但依然会占用一个block,因此会潜在地浪费3KB。
情况2:文件很大(5KB),那么会占用两个block(5KB-4KB后剩下的1KB也要占用一个block)。
为了使用户在读取或写入文件时不用关心底层的硬盘结构,Linux内核中的软件层为用户程序提供了一个VFS(Virtual File System,虚拟文件系统)接口,这样用户实际上在操作文件时就是统一对这个虚拟文件系统进行操作了。如下所示为VFS的架构示意图。从中可见,实际文件系统在VFS下隐藏了自己的特性和细节,这样用户在日常使用时会觉得“文件系统都是一样的”,也就可以随意使用各种命令在任何文件系统中进行各种操作了;
系统会自动判别底层文件系统的格式。
6.4 挂载硬件设备
挂载:当用户需要使用硬盘设备或分区中的数据时,需要先将其与一个已存在的目录文件进行关联,而这个关联动作就是“挂载”;
挂载流程:分区--格式化--挂载;
6.4.1 mount
- 作用:用于挂载文件系统;
- 命令:
mount 文件系统 挂载目录
参数 | 作用 |
---|---|
-a | 挂载所有在/etc/fstab中定义的文件系统(mount -a ,而写到/etc/fstab里的挂载信息才会永久生效,否则单纯用mount挂载设备,重启后失效) |
-t | 指定文件系统的类型 |
如果在工作中要挂载的是一块网络存储设备,名字可能会变来变去,再写sdb就不太合适了。这时推荐用UUID(通用唯一识别码)进行挂载操作,这是一串用于标识每块独立硬盘的字符串,具有唯一性及稳定性,特别适合挂载网络设备时使用。
blkid命令用于显示设备的属性信息,英文全称为:“block id”,语法格式为:blkid [设备名]
如果不知道是哪个设备,就用lsblk
命令
- 示例:
[root@linuxfirst ~]# mount /dev/sdb2 /backup
[root@linuxfirst ~]# blkid
/dev/sdb1: UUID="2db66eb4-d9c1-4522-8fab-ac074cd3ea0b" TYPE="xfs" PARTUUID="eb23857a-01"
/dev/sdb2: UUID="478fRb-1pOc-oPXv-fJOS-tTvH-KyBz-VaKwZG" TYPE="ext4" PARTUUID="eb23857a-02"
[root@linuxfirst ~]# mount UUID=478fRb-1pOc-oPXv-fJOS-tTvH-KyBz-VaKwZG /backup
- /etc/fstab 挂载信息格式:
字段 | 意义 |
---|---|
设备文件 | 一般为设备的路径+设备名称,也可以写唯一识别码(UUID,Universally Unique Identifier) |
挂载目录 | 指定要挂载到的目录,需在挂载前创建好 |
格式类型 | 指定文件系统的格式,比如Ext3、Ext4、XFS、SWAP、iso9660(此为光盘设备)等 |
权限选项 | 若设置为defaults,则默认权限为:rw, suid, dev, exec, auto, nouser, async |
是否备份 | 若为1则开机后使用dump进行磁盘备份,为0则不备份 |
是否自检 | 若为1则开机后自动进行磁盘自检,为0则不自检 |
## 写入/etc/fstab
#
# /etc/fstab
# Created by anaconda on Sat Jan 9 00:48:19 2021
#
# Accessible filesystems, by reference, are maintained under '/dev/disk/'.
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info.
#
# After editing this file, run 'systemctl daemon-reload' to update systemd
# units generated from this file.
#
/dev/mapper/rhel-root / xfs defaults 0 0
UUID=c33e8afc-a19c-4833-9625-659cca1e5322 /boot xfs defaults 0 0
/dev/mapper/rhel-swap swap swap defaults 0 0
/dev/sdb1 /newFS xfs defaults 0 0
~
6.4.2 umount
- 作用:撤销已经挂在的设备文件;
- 命令:
umount [设备文件/挂载目录]
,只需要设备文件或挂载目录任意一方就行; - 示例:
[root@linuxfirst ~]# umount /dev/sdb1
6.5 添加硬盘设备
6.5.1 挂载实操
分区 -----> 格式化 ------> 挂载
6.5.1.1 分区
fdisk
- 作用:新建、修改及删除磁盘的分区表信息(format disk);它提供了集添加、删除、转换分区等功能于一身的“一站式分区服务”,交互式操作;
- 命令:
fdisk 磁盘名称
交互参数 | 作用 |
---|---|
m | 查看全部可用的参数 |
n | 添加新的分区 |
d | 删除某个分区信息 |
l | 列出所有可用的分区类型 |
t | 改变某个分区的类型 |
p | 查看分区表信息 |
w | 保存并退出 |
q | 不保存直接退出 |
- 分区实例:
[root@localhost ~]# ls -l /dev/sd* # 查看硬件设备,/dev/sdb 就是要分区的设备
brw-rw----. 1 root disk 8, 0 Jan 18 04:47 /dev/sda
brw-rw----. 1 root disk 8, 1 Jan 18 04:47 /dev/sda1
brw-rw----. 1 root disk 8, 2 Jan 18 04:47 /dev/sda2
brw-rw----. 1 root disk 8, 16 Jan 18 04:47 /dev/sdb
[root@localhost ~]# fdisk /dev/sdb # 开始分区
Welcome to fdisk (util-linux 2.32.1).
Changes will remain in memory only, until you decide to write them.
Be careful before using the write command.
Device does not contain a recognized partition table.
Created a new DOS disklabel with disk identifier 0x9829c7ae.
Command (m for help): m # 查看全部可用交互参数
Help:
DOS (MBR)
a toggle a bootable flag
b edit nested BSD disklabel
c toggle the dos compatibility flag
Generic
d delete a partition
F list free unpartitioned space
l list known partition types
n add a new partition
p print the partition table
t change a partition type
v verify the partition table
i print information about a partition
Misc
m print this menu
u change display/entry units
x extra functionality (experts only)
Script
I load disk layout from sfdisk script file
O dump disk layout to sfdisk script file
Save & Exit
w write table to disk and exit
q quit without saving changes
Create a new label
g create a new empty GPT partition table
G create a new empty SGI (IRIX) partition table
o create a new empty DOS partition table
s create a new empty Sun partition table
Command (m for help): n # 新建一个分区
Partition type
p primary (0 primary, 0 extended, 4 free)
e extended (container for logical partitions)
Select (default p): p # 新建一个主分区
Partition number (1-4, default 1): 1 # 分区编号设为1
First sector (2048-41943039, default 2048): # 默认从初始扇区开始使用,最大化利用扇区
Last sector, +sectors or +size{K,M,G,T,P} (2048-41943039, default 41943039): +2G # 分配2G,自动计算
Created a new partition 1 of type 'Linux' and of size 2 GiB. # 分好区后
Command (m for help): p # 查看分区表信息,有一个2G的新分区
Disk /dev/sdb: 20 GiB, 21474836480 bytes, 41943040 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: dos
Disk identifier: 0x9829c7ae
Device Boot Start End Sectors Size Id Type
/dev/sdb1 2048 4196351 4194304 2G 83 Linux
Command (m for help): w # 保存退出
The partition table has been altered.
Calling ioctl() to re-read partition table.
Syncing disks.
PS:(若看不到/dev/sdb1这个新建分区,则:)在上述步骤执行完毕之后,Linux系统会自动把这个硬盘主分区抽象成/dev/sdb1设备文件。可以使用file命令查看该文件的属性,但是在讲课和工作中发现,有些时候系统并没有自动把分区信息同步给Linux内核,而且这种情况似乎还比较常见(但不能算作是严重的bug)。我们可以输入partprobe命令手动将分区信息同步到内核,而且一般推荐连续两次执行该命令,效果会更好。如果使用这个命令都无法解决问题,那么就重启计算机吧,这个杀手锏百试百灵,一定会有用的。
6.5.1.2 格式化:
mkfs
- 作用:格式化分区;
- 命令:
mkfs.格式 设备
,输入mkfs双击tab就能看到支持格式化的格式了; - 格式化实例:
## 格式化
[root@localhost ~]# mkfs.xfs /dev/sdb1 # 使用xfs格式化新分区
meta-data=/dev/sdb1 isize=512 agcount=4, agsize=131072 blks
= sectsz=512 attr=2, projid32bit=1
= crc=1 finobt=1, sparse=1, rmapbt=0
= reflink=1
data = bsize=4096 blocks=524288, imaxpct=25
= sunit=0 swidth=0 blks
naming =version 2 bsize=4096 ascii-ci=0, ftype=1
log =internal log bsize=4096 blocks=2560, version=2
= sectsz=512 sunit=0 blks, lazy-count=1
realtime =none extsz=4096 blocks=0, rtextents=0
6.5.1.3 挂载并执行mount -a 使挂载生效 + 写入/etc/fstab,
执行完后重启可以使用df -h
(Disk Free)命令查看挂载状态和硬盘使用量信息
[root@localhost ~]# mkdir /newFS # 要提前创建分区挂载的目录
[root@localhost ~]# mount /dev/sdb1 /newFS/ # 挂载分区
[root@localhost ~]# df -h
Filesystem Size Used Avail Use% Mounted on
devtmpfs 969M 0 969M 0% /dev
tmpfs 984M 0 984M 0% /dev/shm
tmpfs 984M 9.6M 974M 1% /run
tmpfs 984M 0 984M 0% /sys/fs/cgroup
/dev/mapper/rhel-root 17G 4.0G 14G 24% /
/dev/sda1 1014M 152M 863M 15% /boot
tmpfs 197M 16K 197M 1% /run/user/42
tmpfs 197M 3.4M 194M 2% /run/user/0
/dev/sr0 6.7G 6.7G 0 100% /run/media/root/RHEL-8-0-0-BaseOS-x86_64
/dev/sdb1 2.0G 47M 2.0G 3% /newFS # 可以看到已经挂载生效
## 写入/etc/fstab
~ # 将设备 /dev/sdb1 挂载到 /newFS 目录下,格式为 XFS,默认授权,不备份不开机自检
/dev/sdb1 /newFS xfs defaults 0 0
~
## 重启使用 df -h 查看,挂载设备依旧有效
[root@localhost ~]# df -h
Filesystem Size Used Avail Use% Mounted on
devtmpfs 969M 0 969M 0% /dev
tmpfs 984M 0 984M 0% /dev/shm
tmpfs 984M 9.6M 974M 1% /run
tmpfs 984M 0 984M 0% /sys/fs/cgroup
/dev/mapper/rhel-root 17G 4.0G 14G 24% /
/dev/sdb1 2.0G 47M 2.0G 3% /newFS # <----
/dev/sda1 1014M 152M 863M 15% /boot
tmpfs 197M 16K 197M 1% /run/user/42
tmpfs 197M 3.4M 194M 2% /run/user/0
/dev/sr0 6.7G 6.7G 0 100% /run/media/root/RHEL-8-0-0-BaseOS-x86_64
6.5.2 du
- 作用:查看文件占用的存储容量(文件大小);
- 格式:
du [选项] [文件]
;常用的是du -sh [文件]
- 实例:
[root@localhost ~]# du -sh /boot
113M /boot # /boot目录大小为113M
6.6 添加交换分区
交换分区即虚拟内存;
SWAP(交换)分区是一种通过在硬盘中预先划分一定的空间,然后将把内存中暂时不常
用的数据临时存放到硬盘中,以便腾出物理内存空间让更活跃的程序服务来使用的技术,其设
计目的是为了解决真实物理内存不足的问题。但由于交换分区毕竟是通过硬盘设备读写数据的,
速度肯定要比物理内存慢,所以只有当真实的物理内存耗尽后才会调用交换分区的资源。
添加交换分区的步骤:分区 -- mkswap格式化 -- swapon挂载 -- 写入/etc/fstab
6.6.1 分区
[root@localhost ~]# fdisk /dev/sdb # 对此盘进行分区
Welcome to fdisk (util-linux 2.32.1).
Changes will remain in memory only, until you decide to write them.
Be careful before using the write command.
Command (m for help): p # 查看分区表
Disk /dev/sdb: 20 GiB, 21474836480 bytes, 41943040 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: dos
Disk identifier: 0x9829c7ae
Command (m for help): n # 新建一个分区
Partition type
p primary (0 primary, 0 extended, 4 free)
e extended (container for logical partitions)
Select (default p): p # 新建类型为主分区
Partition number (1-4, default 1): # 分区编号默认为1
First sector (2048-41943039, default 2048): # 其实扇区默认2048
Last sector, +sectors or +size{K,M,G,T,P} (2048-41943039, default 41943039): +2G # 创建分区大小为2G
Created a new partition 1 of type 'Linux' and of size 2 GiB.
Partition #1 contains a xfs signature.
Do you want to remove the signature? [Y]es/[N]o: y
The signature will be removed by a write command.
Command (m for help): w # 保存并推出
The partition table has been altered.
Calling ioctl() to re-read partition table.
Syncing disks.
[root@localhost ~]# ls -l /dev/sd* # 查看分区是否成功
brw-rw----. 1 root disk 8, 16 Jan 27 22:33 /dev/sdb
brw-rw----. 1 root disk 8, 17 Jan 27 22:33 /dev/sdb1 # 成功分区
6.6.2 mkswap格式化
使用交换分区特殊格式化命令mkswap
格式化分区
[root@localhost ~]# mkswap /dev/sdb1
Setting up swapspace version 1, size = 2 GiB (2147479552 bytes)
no label, UUID=88c5120e-0f94-44dd-bc99-dafe747ff953
6.6.3 swapon挂载及写入/etc/fstab
使用交换分区特殊挂载命令swapon
挂载分区;
将该在信息写入配置文件中,永久生效,注意挂载目录和分区格式为swap
[root@localhost ~]# free -h # 查看当前内存,虚拟内存2G
total used free shared buff/cache available
Mem: 1.9Gi 1.2Gi 189Mi 16Mi 541Mi 553Mi
Swap: 2.0Gi 0B 2.0Gi
[root@localhost ~]# swapon /dev/sdb1 # 挂载交换分区
[root@localhost ~]# free -h # 虚拟内存变为4G
total used free shared buff/cache available
Mem: 1.9Gi 1.2Gi 187Mi 16Mi 541Mi 551Mi
Swap: 4.0Gi 0B 4.0Gi
[root@localhost ~]# vim /etc/fstab # 将挂载信息写入配置文件,永久生效
/dev/sdb1 swap swap defaults 0 0
6.7 磁盘容量配额
root管理员使用磁盘容量配额服务来限制某位用户或某个用户组针对特定文件夹可以使用的最大硬盘空间或最大文件个数,一旦达到这个最大值就不再允许继续使用,这就是磁盘容量配额;
可以使用quota技术进行磁盘容量配额管理,从而限制用户的硬盘可用容量或所能创建的最大文件个数。quota技术还有软限制和硬限制的功能。
- 软限制:当达到软限制时会提示用户,但仍允许用户在限定的额度内继续使用(写入日志)。
- 硬限制:当达到硬限制时会提示用户,且强制终止用户的操作。
RHEL 7,8 中已经安装了quota 磁盘容量配额服务程序包,但存储设备却默认没有开启对quota 的支持,此时需要手动编辑配置文件/etc/fstab;
RHEL 6中配置是用usrquota
,但RHEL 7,8中改为了uquota
6.7.1 开启目录磁盘配额技术
使用uquota
对指定目录开启quota,并使用mount命令查看此目录的信息
[root@linuxprobe ~]# vim /etc/fstab
#
# /etc/fstab
# Created by anaconda on Tue Jul 21 05:03:40 2020
#
# Accessible filesystems, by reference, are maintained under '/dev/disk/'.
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info.
#
# After editing this file, run 'systemctl daemon-reload' to update systemd
# units generated from this file.
#
/dev/mapper/rhel-root / xfs defaults 1 1
UUID=812b1f7c-8b5b-43da-8c06-b9999e0fe48b /boot xfs defaults,uquota 1 2 # 此处就是对/boot目录配置了quota技术
/dev/mapper/rhel-swap swap swap defaults 0 0
/dev/cdrom /media/cdrom iso9660 defaults 0 0
/dev/sdb1 /newFS xfs defaults 0 0
/dev/sdb2 swap swap defaults 0 0
[root@linuxprobe ~]# mount | grep /boot # 可以看到已经开启了quota技术
/dev/sda1 on /boot type xfs (rw,relatime,seclabel,attr2,inode64,usrquota)
6.7.2 配置用户的磁盘限额
xfs_quota
- 作用:专门针对XFS 文件系统来管理quota 磁盘容量配额服务而设计的命令;
- 格式:
quota [参数] 配额文件系统
参数 | 作用 |
---|---|
-c | 以参数的形式设置要执行的命令 |
-x | 专家模式,让运维人员能够对quota 服务进行更多复杂的配置 |
- 实例:
isoft ihard :对inode的软限制与硬限制(文件个数)
bsoft bhard:对block的软限制与硬限制(磁盘容量)
# 给用户tom设置磁盘配额,设置磁盘容量软硬限制为:3M和6M,文件个数软硬限制为3个和6个
[root@linuxprobe ~]# xfs_quota -x -c 'limit bsoft=3m bhard=6m isoft=3 ihard=6 tom' /boot
[root@linuxprobe ~]# xfs_quota -x -c report /boot # 查看目录所有磁盘容量软硬限制
User quota on /boot (/dev/sda1)
Blocks
User ID Used Soft Hard Warn/Grace
---------- --------------------------------------------------
root 114964 0 0 00 [--------]
tom 0 3072 6144 00 [--------]
6.7.3 修改用户磁盘限额
edquota
- 作用:编辑用户的quota 配额限制;edquota 命令会调用Vi 或Vim 编辑器来让root 管理员修改要限制的具体细节。
- 格式:
edquota [参数] [用户]
参数 | 作用 |
---|---|
-u | 表示要针对哪个用户进行设置 |
-g | 表示要针对哪个用户组进行设置 |
- 实例:
[root@linuxprobe ~]# edquota -u tom
Disk quotas for user tom (uid 1001):
Filesystem blocks soft hard inodes soft hard # blocks 和 inodes 表示已经使用的block和inode
/dev/sda 6144 3072 8192 1 3 6
6.8 软硬连接
文件详细信息中的 1
就是表示文inode个数
[root@localhost ~]# ls -l initial-setup-ks.cfg
-r-xr-xr-x. 1 linuxtest linuxtest 1550 Jan 9 01:22 initial-setup-ks.cfg
硬链接:复制了原文件的一份inode;每新增一个硬链接,inode个数加一;此时删除原文件,只会删除原文件的inode,通过硬链接依然可以打开文件;注意硬链接不能跨分区;
软连接:只是指向原文件inode的一个指针;删除原文件,则软连接就会失效;软连接可以跨文件系统。
ln
- 作用:创建链接文件;
- 格式:
ln [选项] 目标
参数 | 作用 |
---|---|
-s | 创建“符号链接”(如果不带-s参数,则默认创建硬链接) |
-f | 强制创建文件或目录的链接 |
-i | 覆盖前先询问 |
-v | 显示创建链接的过程 |
- 实例:
[root@localhost ~]# ln -s initial-setup-ks.cfg ini.cfg # 创建软连接