Linux 磁盘管理

Strong 2020年04月14日 215次浏览

磁盘管理

1、磁盘简介

1.1 认识磁盘

磁盘是一种计算机的外部存储器设备,由一个或多个覆盖有磁性材料的铝制或玻璃制的碟片组成,用来存储用户的信息,这种信息可以反复地被读取和改写;绝大多数磁盘被永久封存在一个密封的盒子里。

磁盘结构1.jfif

1.2 磁盘运行机理

简单来说就是多个盘片之间靠主轴连接,电机带动主轴做旋转运动,通过多个磁头臂的摇摆和磁盘的旋转,磁头就可以在磁盘旋转的过程中就读取到磁盘中存储的各种数据。

1.3 磁盘的扇区、磁道、柱面

磁道: 磁盘的每个盘面被划分为许多同心圆,这些同心圆的轨道叫做磁道。

扇区: 一个盘面划分为若干个内角相同的扇形,这样盘面上的每个磁道就被分为若干段圆弧,每段圆弧叫做一个扇区。每个扇区中的数据作为一个单元同时被读入或写入。每一个扇区是512字节,其中有64个字节存储的是分区表,一条分区信息占16个字节。

柱面: 每一个盘片同一大小的同心圆可以看成连在一起的柱面,磁盘在分区的时候最小单位是柱面,每一个盘片的上下面都可以读取数据,每一个磁头,不可以跨盘面读取数据。

1.4 磁盘的分类

IDE接口磁盘: 特点价格低廉,兼容性强,性价比高,数据传输较慢,不支持热插拔等。

SCSI接口磁盘: 传输速率高,读写性能好,运行稳定,可连接多个设备;可支持热插拔,占用CPU低,但是价格相对来说比较贵,一般用于工作站或服务器上。

SATA接口磁盘: 结构简单、支持热插拔。

USB接口磁盘: 移动硬盘,随身携带,性能较低。

IDE接口的磁盘在Linux系统中命名为:/dev/hd[a-z]

SCSI、SATA、USB接口的磁盘在Linux系统中命名为:/dev/sd[a-z]

虚拟化磁盘在Linux系统中命名为:/dev/vd[a-z]

2、磁盘分区

2.1 为什么要分区?

易于管理和使用:
比如说我们把磁盘分成多个盘(分区)sda1、sda2、sda3、sda4,假设sda1盘为系统盘,其他的比如说游戏、办公、软件盘,这样我们想管理哪个盘直接选中操作即可不会影响其他盘;而且根据用途我们也能较快的去使用相应的磁盘。

有利于数据的安全:
通过分区可以降低数据损失的风险;出现硬盘坏道、错误操作、重装系统都有可能造成数据损失,如果分区了,那么我们就可以将损失最小化。

节约寻找文件的时间:
寻找文件的时间是指电脑搜索文件的时间;分区以后,电脑搜索文件时只需要在相对应的分区搜索就可以了,没必要进行全盘搜索,大大节省了寻找文件的时间。

磁盘分区图示:
磁盘分区.jfif

2.2 分区类型

MBR(Master Boot Record)和GPT(GUID Partition Table)是在磁盘上存储分区信息的两种不同方式;这些分区信息包含了分区从哪里开始的信息,这样操作系统才知道哪个扇区是属于哪个分区的,以及哪个分区是可以启动的。在磁盘上创建分区时,你必须在MBR和GPT之间做出选择。

MBR是Master Boot Record的简称,也就是主引导记录,是位于磁盘最前边的一段引导(Loader)代码,主要用来引导操作系统的加载与启动。

特点:

  • MBR支持最大2TB磁盘,它无法处理大于2TB容量的磁盘
  • 只支持最多4个主分区。若想要更多分区,需要创建扩展分区,并在其中创建逻辑分区

GPT磁盘是指使用GUID分区表的磁盘,GUID磁盘分区表(GUID Partition Table,缩写:GPT)其含义为“全局唯一标识磁盘分区表”,是一个实体硬盘的分区表的结构布局的标准。

特点:

  • GPT对磁盘大小没有限制
  • 最多可以创建128个分区

3、分区工具使用

3.1 查看分区使用情况

df	//命令查看已挂载磁盘使用情况,默认K为单位
-i	//查看inode使用情况
-h	//以G或者T或者M人性化方式显示
-T	//查看文件系统类型

[root@localhost ~]# df -h
设备名称      	  磁盘大小 已用大小 可用大小 使用百分比 挂载点
Filesystem             Size  Used  Avail   Use%      Mounted on
devtmpfs               1.9G     0   1.9G     0%      /dev
tmpfs                  1.9G     0   1.9G     0%      /dev/shm
tmpfs                  1.9G  9.7M   1.9G     1%      /run
tmpfs                  1.9G     0   1.9G     0%     
 /sys/fs/cgroup
/dev/mapper/rhel-root   55G   14G    42G    26%      /
/dev/sr0               7.9G  7.9G      0   100%      /mnt/cdrom
/dev/nvme0n1p1        1014M  229M   786M    23%      /boot
tmpfs                  376M  4.0K   376M     1%      /run/user/0
tmpfs                  376M  1.2M   375M     1%      /run/user/42

lsblk	//查看所有磁盘和分区使用情况
[root@localhost ~]# lsblk 
NAME          MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
sr0            11:0    1  7.9G  0 rom  /mnt/cdrom
nvme0n1       259:0    0   60G  0 disk 
|-nvme0n1p1   259:1    0    1G  0 part /boot
|-nvme0n1p2   259:2    0   19G  0 part 
| |-rhel-root 253:0    0   55G  0 lvm  /
| `-rhel-swap 253:1    0    2G  0 lvm  [SWAP]
`-nvme0n1p3   259:3    0   40G  0 part 
  `-rhel-root 253:0    0   55G  0 lvm  /

du	//统计文件占用磁盘大小
-s	//列出总和
-h	//人性化显示容量信息

[root@localhost ~]# du -sh /etc/
30M     /etc/

3.2 磁盘分区工具

分区工具有fdisk和gdisk,当硬盘小于2T的时候我们应该用fdisk来分区,而当硬盘大于2T的时候则应用gdisk来进行分区;fdisk默认使用MBR分区表,gdisk默认使用GPT分区表。

//生产分区建议: 如无特殊需求, 直接使用整个磁盘即可, 无需分区
//学习分区建议:1P+1E(3L) 2P+1E(2L) 3P+1E(1L) (仅适用于练习)      

fdisk	//磁盘分区工具,默认采用MBR分区表
-l	//列出系统中所有磁盘

[root@localhost ~]# fdisk -l			//查看系统中磁盘信息

[root@localhost ~]# fdisk  /dev/sdb		//对/dev/sdb进行分区
Command (m for help): m 			//获取帮助
Command action
   a   toggle a bootable flag   		//切换分区启动标记
   d   delete a partition     			//删除分区
   l   list known partition types   		//显示分区类型
   m   print this menu      			//显示帮助菜单
   n   add a new partition  			//新建分区
   o   create a new empty DOS partition table   //创建新的空白分区表
   p   print the partition table       		//显示分区表的信息
   q   quit without saving changes  		//不保存退出
   t   change a partition's system id   	//修改分区ID类型,可以通过l查看id
   w   write table to disk and exit     	//保存退出

//创建主分区
Command (m for help): n 			//新建分区
Partition type:
   p   primary (0 primary, 0 extended, 4 free)  //主分区
   e   extended 				//扩展分区
Select (default p): p   			//选择主分区
Partition number (1-4, default 1):  		//分区序号
First sector (2048-2097151, default 2048): 	//起始扇区位置,回车默认即可
Using default value 2048
Last sector, +sectors or +size{K,M,G} (2048-2097151, default 2097151): +50M //结束扇区位置,+50M表示此分区大小为50MB

//创建扩展分区
Command (m for help): n 			//新建分区
Partition type:
   p   primary (1 primary, 0 extended, 3 free)
   e   extended
Select (default p): e   			//创建扩展分区
Partition number (2-4, default 2):
First sector (104448-2097151, default 104448):
Using default value 104448
Last sector, +sectors or +size{K,M,G} (104448-2097151, default 2097151):  //回车默认划分所有空间给扩展分区

//创建逻辑分区
Command (m for help): n 			//新建分区
Partition type:
   p   primary (1 primary, 1 extended, 2 free)
   l   logical (numbered from 5)
Select (default p): l   			//创建逻辑分区
Adding logical partition 5
First sector (106496-2097151, default 106496):
Using default value 106496
Last sector, +sectors or +size{K,M,G} (106496-2097151, default 2097151): +100M  //分配100MB空间

//查看分区创建
Command (m for help): p
Device Boot      Start         End      Blocks   Id  System
/dev/sdb1            2048      104447       51200   83  Linux
/dev/sdb2          104448     2097151      996352    5  Extended
/dev/sdb5          106496      311295      102400   83  Linux

//保存分区
Command (m for help): w
The partition table has been altered!
Calling ioctl() to re-read partition table.
Syncing disks.

//检查磁盘是否是MBR分区方式
[root@localhost ~]# fdisk -l /dev/sdb | grep type
Disk label type: dos

//安装parted, 刷新内核立即生效分区配置,无需重启
[root@localhost ~]# dnf -y install parted
[root@localhost ~]# partprobe /dev/sdb
gdisk	//磁盘分区工具,默认采用GPT分区表

[root@localhost ~]# gdisk /dev/sdb
Command (? for help): n     			//创建新分区
Partition number (1-128, default 1):
First sector (34-2097118, default = 2048) or {+-}size{KMGTP}:
Last sector (2048-2097118, default = 2097118) or {+-}size{KMGTP}: +500M //分配500M大小

Command (? for help): p 			//查看分区情况
Number  Start (sector)    End (sector)  Size       Code  Name
   1            2048         1026047   500.0 MiB   8300  Linux filesystem

Command (? for help): w 			//保存分区
Do you want to proceed? (Y/N): y    		//确认
OK; writing new GUID partition table (GPT) to /dev/sdb.
The operation has completed successfully.

//检查磁盘是否是gpt格式
[root@localhost /]# fdisk /dev/sdb -l | grep type
Disk label type: gpt

//安装parted, 刷新内核立即生效分区配置,无需重启
[root@localhost ~]# yum -y install parted
[root@localhost ~]# partprobe /dev/sdb

3.2 磁盘格式化

mkfs命令用来格式化磁盘,创建文件系统;磁盘分区后必须格式化创建文件系统才能正常使用。


mkfs	//格式化磁盘或分区
-b	//设定数据区块占用空间大小,目前支持1024、2048、4096 bytes每个块。
-t	//用来指定什么类型的文件系统,可以是ext3,ext4, xfs
-i	//设定inode的大小
-N	//设定inode数量,防止Inode数量不够导致磁盘不足
-L	//预设该分区的标签label

//格式化整个sdb磁盘为ext4文件系统
[root@localhost ~]# mkfs.ext4  /dev/sdb1

//也可以使用-t指定方式创建ext4文件系统
[root@localhost ~]# mkfs -t ext4  /dev/sdb1

//也可以格式化sdb1分区为xfs文件系统
[root@localhost ~]# mkfs.xfs  /dev/sdb1

3.3 磁盘挂载

磁盘分区和格式化之后, 在Linux中必须进行挂载才能进行使用;挂载分区前需要创建挂载点, 挂载点就是一个目录,如果往挂载点目录写入数据, 实际上会写入到挂载的分区当中;挂载点建议是空目录, 如果不是也不影响挂载分区的使用,但是原有的文件会被隐藏。

挂载分为两种临时挂载和永久挂载;临时挂载即重启之后失效,永久挂载即开机自动挂载。

临时挂载磁盘:

mount		//磁盘挂载命令,实质为文件系统指定访问入口
-t		//指定文件系统挂载分区,如ext3,ext4, xfs
-o		//指定挂载参数
-a		//重新读取/etc/fstab配置文件的所有挂载

//挂载/dev/sdb1至db1目录
[root@localhost ~]# mkdir /mnt/disk1
[root@localhost ~]# mount -t xfs /dev/sdb1  /mnt/disk1

//fstab被损坏情况下,让只读文件系统可写(正常情况下不使用)
[root@localhost ~]#mount -o rw,remount /

永久挂载磁盘:

blkid		//获取所有分区的UUID

//blkid命令获取sdb1分区的UUID
[root@localhost ~]# blkid | grep "sdb1"
/dev/sdb1: UUID="e271b5b2-b1ba-4b18-bde5-66e394fb02d9" TYPE="xfs"

//使用UUID临时挂载磁盘sdb1分区至于db1
[root@localhost ~]# mount UUID="e271b5b2-b1ba-4b18-bde5-66e394fb02d9" /mnt/disk1

//将挂载写入到/etc/fstab中,实现永久挂载, 开机自动挂载
[root@localhost ~]# vim /etc/fstab    
UUID=e271b5b2-b1ba-4b18-bde5-66e394fb02d9 /mnt/disk1 xfs  defaults 0  0

//加载fstab配置文件, 同时检测语法是否有错误
[root@localhost ~]# mount –a

fstab配置文件介绍:

[root@localhost ~]# vim /etc/fstab
分区标识(UUID或设备名)                       挂载点      文件类型  挂载参数    不检查 不备份
UUID=e271b5b2-b1ba-4b18-bde5-66e394fb02d9 /mnt/disk1     xfs     defaults    0     0

//挂载参数, 可写fstab配置文件, 也可以mount时使用-o参数指定
参数             参数意义                                  系统默认值
async            系统每隔一段时间把内存数据写入磁盘中
sync             时时同步内存和磁盘中数据;
suid,nosuid     允许/不允许分区有suid属性                  suid
rw,ro           可以指定文件系统是只读(ro)或可写(rw)        rw
exec,noexec     允许/不允许可执行文件执行,不要挂载根分区    exec
user,nouser     允许/不允许root外的其他用户挂载分区         nouser
auto,noauto     开机自动挂载/不自动挂载                    auto
default          默认文件系统挂载设置			  rw, suid, dev, exec, auto, nouser, async

//加载fstab配置文件中所有配置
[root@localhost ~]# mount -a

卸载挂载磁盘:

umount		//取消挂载
-lf		//强制取消挂载

//使用站点目录卸载
[root@localhost ~]# umount /mnt/disk1

//使用设备名卸载/dev/sdb1
[root@localhost ~]# umount /dev/sdb1

//umount不能卸载的情况
[root@localhost db1]# umount /db1  
umount: /db1: device is busy.
        (In some cases useful info about processes that use
         the device is found by lsof(8) or fuser(1)
       
//如上情况解决办法有两种, 切换至其他目录或使用'-l'选项强制卸载    
[root@localhost db1]# umount -lf /db1

4、SWAP交换分区

交换分区SWAP就是LINUX下的虚拟内存分区,它的作用是在物理内存使用完之后,将磁盘空间(也就是SWAP分区)虚拟成内存来使用。交换分区一般指定虚拟内存的大小为实际内存的1~1.5倍。如果实际内存超过8GB,可以直接划分16GB给虚拟内存即可。

//为系统添加SWAP分区

//查看内存和SWAP交换分区的使用情况
# free -m
              total        used        free      shared  buff/cache   available
Mem:           3752         639        2496          10         616        2871
Swap:             0           0           0 <--- 没有交换分区

# swapon -s  也能用该命令查看

//使用磁盘创建一个分区作为SWAP交换分区,并且把分区类型更改为82

# fdisk  /dev/sdb

Command (m for help): n 			//新建分区
Partition type:
   p   primary (0 primary, 0 extended, 4 free)
   e   extended
Select (default p): p   			//选择主分区
Partition number (1-4, default 1):  		//分区序号
First sector (2048-2097151, default 2048): 	//起始扇区位置,回车默认即可
Using default value 2048
Last sector, +sectors or +size{K,M,G} (2048-2097151, default 2097151): +2G //结束扇区位置,+2G表示此分区大小为2G

Select (default p): t				//修改分区id
Partition number (default 1)			//选择要成为SWAP的分区
Hex code (type L to list all codes):82  	//修改成id为82
Changed type of partition 'Linux LVM' to 'Linux swap / Solaris'.

Command (m for help): p

   设备 Boot      Start         End      Blocks   Id  System
/dev/sdb1            2048     2099199     1048576   83  Linux
/dev/sdb2         2099200     6293503     2097152   82  Linux swap / Solaris <---修改成功

Command (m for help): w

//强烈建议: 对分区做了修改后都刷新一下
# partprobe  /dev/sdb

//把sdb1格式化为交换分区
# mkswap  /dev/sdb1
正在设置交换空间版本 1,大小 = 2097148 KiB
无标签,UUID=ba08eb90-2003-44e6-9769-9a9351aebb05

//启动交换分区
# swapon /dev/sdb1
或者
# swanon -a  启动所有交换分区

//查看交换分区
# swapon -s
文件名             类型           大小  已用  权限
/dev/sdb1         partition   2097148  0     -1

//永久挂载交换分区
# blkid /dev/sdb1
/dev/sdb1: UUID="ba08eb90-2003-44e6-9769-9a9351aebb05" TYPE="swap" 

# vim /etc/fstab 
UUID=ba08eb90-2003-44e6-9769-9a9351aebb05  swap	swap	defaults  0 0

5、生产磁盘故障案例

//Inode被占满,导致磁盘有可用的剩余空间也无法继续使用

[root@localhost ~]# dd if=/dev/zero of=/opt/newdisk bs=1k count=1024
[root@localhost ~]# mkfs.ext4 -i 1024 /opt/newdisk
[root@localhost ~]# mkdir /mnt/data
[root@localhost ~]# mount -t ext4 -o loop /opt/newdisk /mnt/data/

//inode被占满
[root@localhost ~]# cd /mnt/data/
[root@localhost data]# touch {1..20000}
touch: cannot touch `19997': No space left on device
touch: cannot touch `19998': No space left on device
touch: cannot touch `19999': No space left on device
touch: cannot touch `20000': No space left on device

//inode被占满,剩余block也是无法继续使用
[root@localhost ~]# df -h|grep data
/opt/newdisk    891K   34K  806K   5% /mnt/data/

[root@localhost ~]# df -i | grep data
/opt/newdisk      1024  1024       0  100% /mnt/data/

//假设现在线上正在运行Nginx服务, Nginx产生的日志已经达到了20个G, 磁盘眼看就看沾满了, 请问不重启Nginx的方式如何处理

//删除文件, 但虽然文件被删除但是Nginx持续占用着文件, 所以空间并不会被释放
rm -f access.log

//正确做法如下, 使用重定向清空该文件即可释放文件内容
> access.log

6、LVM逻辑卷管理

6.1 LVM逻辑卷的作用

许多Linux使用者安装操作系统时都会遇到这样的困境:如何精确评估和分配各个硬盘分区的容量,如果当初评估不准确,一旦系统分区不够用时可能不得不备份、删除相关数据,甚至被迫重新规划分区并重装操作系统,以满足系统的需要。

LVM逻辑卷管理是一个多才多艺的硬盘系统工具;无论在Linux或者其他类似的系统,都是非常的好用。传统分区使用固定大小分区,重新调整大小十分麻烦。但是,LVM可以创建和管理“逻辑”卷,而不是直接使用物理硬盘。可以让管理员弹性的管理逻辑卷的扩大缩小,操作简单,而不损坏已存储的数据。可以随意将新的硬盘添加到LVM,以直接扩展已经存在的逻辑卷。

lvm.jpg

6.2 LVM逻辑卷中的名词

Physical Extend:物理拓展简称PE,逻辑卷管理的基本单位,默认大小是4M。

Physical Volume:物理卷简称PV,将一块磁盘或分区拆分为一个个PE,那么这块磁盘或分区就是PV。

Volume Group:卷组简称VG,一个空间池用来装PE;可以把一个或者多个PV加到VG当中,此时VG中就有了存储空间。

Logical Volume:逻辑卷简称LV,VG的空间不能够直接使用需要从VG中将空间提取出来,提取出来的空间就叫LV;LV的大小必须是PE的倍数。

6.3 创建LVM逻辑卷

LVM逻辑卷创建流程:

  1. 添加物理磁盘,创建物理卷
  2. 创建卷组,将物理卷加入卷组
  3. 在卷组中划分逻辑卷
  4. 格式化逻辑卷
  5. 挂载使用
1.准备物理磁盘
[root@localhost ~]# lsblk |grep "sd[bcd]"
sdb             8:16   0    1G  0 disk
sdc             8:32   0    1G  0 disk
sdd             8:48   0    1G  0 disk

2.将磁盘转换为pv
[root@localhost ~]# pvcreate /dev/sdb
Physical volume "/dev/sdb" successfully created.

//检查pv创建情况
[root@localhost ~]# pvs
PV         VG     Fmt  Attr PSize   PFree
/dev/sdb          lvm2 ---    1.00g 1.00g

3.创建名为datavg的卷组,此卷组包含/dev/sdb物理卷
[root@localhost ~]# vgcreate datavg /dev/sdb
Volume group "datavg" successfully created

//检查卷组
[root@localhost ~]# vgs
VG      #PV #LV #SN Attr   VSize    VFree
datavg   1   0   0 wz--n- 1020.00m 1020.00m

4.创建逻辑卷, 分配名称, 指定大小和卷组
[root@localhost ~]# lvcreate -L 100M -n lv1 datavg
Logical volume "datalv1" created.

//检查逻辑卷
[root@localhost ~]# lvscan
ACTIVE            '/dev/datavg/lv1' [100.00 MiB] inherit

5.格式化文件系统
[root@localhost ~]# mkfs.xfs /dev/datavg/lv1

//挂载并使用
[root@localhost ~]# mkdir /lv1
[root@localhost ~]# mount /dev/datavg/lv1 /lv1/
[root@localhost ~]# df -h
Filesystem                  Size  Used Avail Use% Mounted on
...
/dev/mapper/datavg-lv1   97M  5.2M   92M   6% /lv1

6.4 卷组管理

扩展卷组,扩大卷组空间

1.将新硬盘转换为pv
[root@localhost ~]# pvcreate /dev/sdc

2.使用vgextend扩展,将新的pv加入到vg
[root@localhost ~]# vgextend datavg /dev/sdc
Volume group "datavg" successfully extended

缩减卷组,缩减卷组空间

[root@localhost ~]# vgreduce datavg /dev/sdb
Removed "/dev/sdb" from volume group "datavg"

数据迁移卷组,同一卷组的PV之间才可以进行在线迁移

1.检查当前逻辑卷VG中PV使用情况
[root@localhost ~]# pvs
PV      VG   Fmt  Attr PSize PFree
/dev/sdb vg1 lvm2 a -- 2.00g 1.76g 
/dev/sdc vg1 lvm2 a -- 2.00g 2.00g

2.pvmove将一个pv的数据迁移至其他pv 
[root@localhost ~]# pvmove /dev/sdb
  /dev/sdb: Moved: 41.33%
  /dev/sdb: Moved: 100.00%

3.检查是否将sdb数据迁移至sdc 
[root@localhost ~]# pvs
PV      VG   Fmt  Attr PSize PFree 
/dev/sdb vg1 lvm2 a -- 2.00g 2.00g 
/dev/sdc vg1 lvm2 a -- 2.00g 1.76g

6.5 逻辑卷管理

逻辑卷扩展,逻辑卷的扩展取决于卷组中的容量,逻辑卷扩展的容量不能超过卷组的容量

[root@localhost ~]# vgs
VG #PV #LV #SN Attr VSize VFree 
vg1 2 2 0 wz --n-   1.88g 1.00g

1.扩展lv逻辑卷
//增加800M分配给逻辑卷 {注意: 800M +800M 不一样}
[root@localhost ~]# lvextend -L +800M /dev/datavg/lv1

//分配磁盘池中多少百分比给逻辑卷
[root@localhost ~]# lvextend -l +50%FREE /dev/datavg/lv1

2.扩展xfs文件系统
//xfs扩容
[root@localhost ~]# xfs_growfs /dev/datavg/lv1

//ext扩容
[root@localhost ~]# resize2fs /dev/datavg/lv1

ext4文件系统的逻辑卷容量裁剪

首先自己创建一个1G的逻辑卷作为裁剪的对象
[root@localhost ~]# lvcreate -L 1G -n uplooking finance

[root@localhost ~]# mkfs.ext4 /dev/finance/uplooking 

[root@localhost ~]# mkdir -p /finance/uplooking

[root@localhost ~]# mount /dev/finance/uplooking /finance/uplooking/

1、如果已经挂载,必须先卸载
[root@localhost ~]# umount /dev/finance/uplooking

2、裁剪容量,必须是先检测文件系统
[root@localhost ~]# e2fsck -f /dev/finance/uplooking

[root@localhost ~]# resize2fs /dev/finance/uplooking 512M

3、调整完毕后采取裁剪逻辑卷容量
[root@localhost ~]# lvreduce  -L 512M /dev/finance/uplooking 
WARNING: Reducing active logical volume to 512.00 MiB
THIS MAY DESTROY YOUR DATA (filesystem etc.)
Do you really want to reduce uplooking? [y/n]: y

4、强烈建议裁剪后,再次检测文件系统
[root@localhost ~]# e2fsck -f /dev/finance/uplooking

5、挂载测试,如果能够挂载,一般说明裁剪成功,文件系统没有损坏
[root@localhost ~]# mount /dev/finance/uplooking /finance/uplooking/
...
/dev/mapper/finance-uplooking  472M  1.6M  435M    1% /finance/uplooking 文件系统容量被刷新了