背景
我在服务器上部署服务,提示磁盘空间不足。但是我记得这个虚拟机服务器,是分配了4T到空间,应该是够用的。因此我分析了一下系统的情况。
- 使用df 指令查看磁盘空间的情况
bash
代码解读
复制代码
sudo df -h /
可以看到总共98G的空间,使用了94G,基本上使用完了。
- 使用fdisk命令查看
bash
代码解读
复制代码
sudo fdisk -l
可以看到sda磁盘总共4T空间,划分为sda1-sda3三个分区。说明我记忆是没错的,空间确实有4T。
看到后面还有一个 /dev/mapper/ubuntu--vg-ubuntu--lv盘,总共100G空间,也就是上面我看到的根目录/的挂载空间。
这个时候我就一头雾水,这个服务器明明只有一个4T磁盘,为啥多了这么个100G的磁盘呢?两者又是什么关系呢?
我观察到100G这个盘的路径里,有一个mapper,是一个映射的结果。我猜测是这100G映射至4T硬盘上的。那这个映射关系是什么呢?
我做了一些调研,终于明白了具体的关系。
- lsblk 展示映射关系
bash
代码解读
复制代码
sudo lsblk -f
可以清楚看到这个虚拟盘,就是映射到sda3上面的。
磁盘、分区、物理卷、卷组、逻辑卷等概念
1. 磁盘(Disk)
磁盘是计算机中用于存储数据的硬件设备。在Linux系统中,磁盘通常以/dev/sdX
或/dev/hdX
的形式表示,其中X
是一个字母,如a
、b
、c
等,代表不同的磁盘。
使用 fdisk -l 命令可以查看到磁盘的信息:
其中磁盘标签类型(也就是分区表类型),gpt(GUID)分区表是一种较新的标准,用于UEFI固件的系统。它提供了更多的灵活性,允许更大的磁盘和更多的分区。GPT磁盘可以有128个分区,并且具有更好的数据保护机制,例如备份分区表。
2. 分区 (Partition)
分区是在磁盘上划分出来的独立存储区域,每个分区可以视为一个独立的磁盘。Linux通过在磁盘上创建多个分区来实现数据的分类存储。分区可以通过fdisk
或gdisk
等工具创建,格式化后可挂载到文件系统的目录下使用。
使用 fdisk -l 可以查看到每个磁盘的分区信息。上面图中可以看到我的sda盘被划分成了sda1-sda3这3个分区。每个分区都有开始和结束的扇区。
3. 物理卷(Physical Volume, PV)
直接对分区进行格式化,就可以挂载到文件系统中,供操作系统使用了。但是这有个问题就是,分区一旦确定,空间大小是无法更改的。扩容和缩容都很麻烦。因此出现了LVM。
在LVM(Logical Volume Manager)中,物理卷是指用来构建卷组的基本存储单元。物理卷可以是一个磁盘的全部或部分分区。例如,在Ubuntu中,你可以将整个磁盘或其某个分区转换为物理卷。但是物理卷本身通常不会被直接挂载,相反,它们会被组合成卷组(VG),然后从卷组中创建逻辑卷(LV)。
下面这个图很好地说明了磁盘、分区、物理卷、逻辑卷组、逻辑卷之间的关系。
查看物理卷
bash
代码解读
复制代码
sudo pvs
或者
bash
代码解读
复制代码
[root@bigdata01 ~]# pvscan PV /dev/sda2 VG centos lvm2 [<49.00 GiB / 0 free] PV /dev/sdd1 lvm2 [<2.00 GiB] PV /dev/sdc1 lvm2 [<2.00 GiB] PV /dev/sdb1 lvm2 [<2.00 GiB] PV /dev/sde1 lvm2 [<2.00 GiB] Total: 5 [56.99 GiB] / in use: 1 [<49.00 GiB] / in no VG: 4 [<8.00 GiB]
4. 卷组(Volume Group, VG)
卷组是由一个或多个物理卷组成的集合,它是逻辑卷的基础。卷组提供了比单个物理卷更大的存储池,允许在其上创建多个逻辑卷。查看命令:
bash
代码解读
复制代码
sudo vgs
5. 逻辑卷(Logical Volume, LV)
逻辑卷是卷组中的可分配存储空间,它类似于传统的磁盘分区,但提供了更多的灵活性。逻辑卷可以在不重新分区的情况下动态调整大小,而且可以跨越多个物理硬盘。查看命令:
bash
代码解读
复制代码
sudo lvs
说明:我们使用mount命令挂载时,通常是指分区或者逻辑卷。
新增磁盘,对逻辑卷扩展或新建
1. 服务器添加磁盘
假设你已经连接了一个新的磁盘,它可能显示为/dev/sdb
。
2. 初始化磁盘
使用parted
或gdisk
创建一个新的分区表。这里我们使用gdisk
:
bash
代码解读
复制代码
sudo gdisk /dev/sdb
然后按照提示创建一个新的分区。
需要注意的是fdisk命令是针对MBR分区的磁盘,gdisk是针对GPT分区磁盘,parted两者都支持。
3. 创建物理卷
将新创建的分区转换为物理卷:
bash
代码解读
复制代码
sudo pvcreate /dev/sdb1
4. 扩展卷组
bash
代码解读
复制代码
sudo vgextend vg_name /dev/sdb1
这里vg_name需要替换为你实际的卷组名称
5. 扩展逻辑卷
现在,你可以选择扩展一个或多个逻辑卷。首先,检查当前卷组的可用空间:
bash
代码解读
复制代码
sudo lvdisplay
然后,扩展逻辑卷
bash
代码解读
复制代码
sudo lvextend -L +10G /dev/vg_name/lv_name
这里的+10G
表示增加10GB的空间,lv_name
需要替换为你的逻辑卷名称。
6. 调整文件系统
最后,你需要调整文件系统以利用新增加的空间:
bash
代码解读
复制代码
sudo resize2fs /dev/vg_name/lv_name
7. 创建新的逻辑卷
如果你不是要扩展已有的逻辑卷,而是要创建一个新的逻辑卷,按照下面方式操作
创建一个新的逻辑卷,并将该卷组的剩余空间加到这个新的逻辑卷上:
perl
代码解读
复制代码
sudo lvcreate -n new_lv -l +100%FREE ubuntu-vg-1
如果该逻辑卷没有格式化,则需要先进行格式化:
bash
代码解读
复制代码
sudo mkfs.xfs /dev/ubuntu-vg-1/new_lv
关于格式化类型:
- EXT4 更适合需要快速读取大量小文件或对兼容性要求较高的场景。
- XFS 更适合需要处理大型文件、高并发访问和高负载的系统。
8. 配置/etc/fstab挂载点
/etc/fstab 文件的每一行代表一个挂载点,格式如下:
xml
代码解读
复制代码
<文件系统> <挂载点> <类型> <选项> <转储> <检查>
其中:
<文件系统>
是设备标识符,可以是设备名(如/dev/sda1
)、UUID 或标签。<挂载点>
是文件系统在文件层次结构中的位置。<类型>
是文件系统的类型,例如xfs
。<选项>
是挂载选项,例如defaults
(表示使用默认选项)、noauto
(表示不自动挂载)、ro
(只读模式)、rw
(读写模式)等。<转储>
是一个整数值,表示是否将文件系统的内容保存到磁带设备中进行备份(0 表示不保存,1 表示保存)。<检查>
是一个整数值,表示在启动时是否对文件系统进行检查(0 表示不检查,1 表示检查,通常根文件系统会被设为 1,其他文件系统设为 2)。
对于使用 mkfs.xfs
格式化的逻辑卷,假设逻辑卷的设备名是 /dev/ubuntu-vg/new_lv
,挂载点是 /data
,你可以按照下面的方式在 /etc/fstab
文件中添加一行:
bash
代码解读
复制代码
UUID=$(blkid -s UUID -o value /dev/ubuntu-vg/new_lv) /data/new_data xfs defaults 0 2 # 或者 /dev/ubuntu-vg/new_lv /data xfs defaults 0 2
执行挂载
css
代码解读
复制代码
sudo mount -a
如果一切正常,这时重启的时候才会自动挂载。
新增磁盘,不使用LVM,直接挂载分区
1. 服务器添加磁盘
假设你已经连接了一个新的磁盘,它可能显示为/dev/sdb
。
2. 初始化磁盘
使用parted
或gdisk
创建一个新的分区表。这里我们使用gdisk
:
bash
代码解读
复制代码
sudo gdisk /dev/sdb
然后按照提示创建一个新的分区sdb1。
需要注意的是fdisk命令是针对MBR分区的磁盘,gdisk是针对GPT分区磁盘,parted两者都支持。
3. 格式化
bash
代码解读
复制代码
sudo mkfs.ext4 /dev/sdb1
关于格式化类型:
- EXT4 更适合需要快速读取大量小文件或对兼容性要求较高的场景。
- XFS 更适合需要处理大型文件、高并发访问和高负载的系统。
4. 创建文件系统上的挂载点
首先,你需要选择一个目录作为挂载点。可以新建一个空目录进行挂载。 例如:
bash
代码解读
复制代码
mkdir /mnt/newDir
5. 配置/etc/fstab挂载点
/etc/fstab 文件的每一行代表一个挂载点,格式如下:
xml
代码解读
复制代码
<文件系统> <挂载点> <类型> <选项> <转储> <检查>
bash
代码解读
复制代码
/dev/sdb1 /mnt/newDir ext4 defaults 0 0
执行挂载
css
代码解读
复制代码
sudo mount -a
如果一切正常,这时重启的时候才会自动挂载。
6. 查看挂载情况
bash
代码解读
复制代码
sudo df -h
我遇到问题的解决过程
1. 查看物理卷情况
可以看到sda3这个分区上,创建了物理卷。该物理卷被挂到了名为ubuntu-vg的卷组上。
2. 查看卷组的情况
可以看到这个卷组总的空间是4T,已经分配的空间是100G,也就是说还有3.9T空间没有被分配,也就是我之前看不到的空间。
3. 查看逻辑卷情况
这里查看的结果也正好对应上。到这里已经明确问题了,卷组空间是有的,但是分配给逻辑卷的空间只有100G,因此要做的是对逻辑卷进行扩展即可,不需要重新格式化磁盘,重装系统啥的。
4. 扩展逻辑卷的空间
bash
代码解读
复制代码
sudo lvextend -L +3.9T /dev/ubuntu-vg/ubuntu-lv
更新文件系统
bash
代码解读
复制代码
sudo resize2fs /dev/ubuntu-vg/ubuntu-lv
查看结果
bash
代码解读
复制代码
sudo df -h
可以看到,已经扩容成功。