RedHat7 LVM分区方案实现挂载点无缝扩容(一)

2023-12-25 19:18

本文主要是介绍RedHat7 LVM分区方案实现挂载点无缝扩容(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先可以使用df -h查看当前各挂载点的情况:

[root@localhost ~]# df -h
文件系统               容量  已用  可用 已用% 挂载点
/dev/mapper/rhel-root   50G  4.5G   43G   10% /
devtmpfs               7.8G     0  7.8G    0% /dev
tmpfs                  7.8G  228K  7.8G    1% /dev/shm
tmpfs                  7.8G   18M  7.8G    1% /run
tmpfs                  7.8G     0  7.8G    0% /sys/fs/cgroup
/dev/sda1              190M  133M   44M   76% /boot
/dev/mapper/rhel-tmp   9.8G   37M  9.2G    1% /tmp
/dev/sr0               3.8G  3.8G     0  100% /run/media/alex/RHEL-7.2 Server.x86_64
tmpfs                  1.6G   88K  1.6G    1% /run/user/0
tmpfs                  1.6G   16K  1.6G    1% /run/user/42
/dev/mapper/rhel-home  4.8G   37M  4.6G    1% /home

注意df -h命令只能看到已经挂载的分区和容量,对于没有挂载的硬盘和现有硬盘没有分配的容量是看不到的,可以使用fdisk -l来查看物理硬盘的情况

[root@localhost ~]# fdisk -l磁盘 /dev/sda:214.7 GB, 214748364800 字节,419430400 个扇区
Units = 扇区 of 1 * 512 = 512 bytes
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节
磁盘标签类型:dos
磁盘标识符:0x0001b91a设备 Boot      Start         End      Blocks   Id  System
/dev/sda1   *        2048      411647      204800   83  Linux
/dev/sda2          411648   180774911    90181632   8e  Linux LVM磁盘 /dev/mapper/rhel-root:53.7 GB, 53687091200 字节,104857600 个扇区
Units = 扇区 of 1 * 512 = 512 bytes
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节磁盘 /dev/mapper/rhel-swap:17.2 GB, 17179869184 字节,33554432 个扇区
Units = 扇区 of 1 * 512 = 512 bytes
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节磁盘 /dev/mapper/rhel-tmp:10.7 GB, 10737418240 字节,20971520 个扇区
Units = 扇区 of 1 * 512 = 512 bytes
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节磁盘 /dev/mapper/rhel-home:5368 MB, 5368709120 字节,10485760 个扇区
Units = 扇区 of 1 * 512 = 512 bytes
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节

从这里,我们看出/dev/sda 这是一块硬盘,这块硬盘的总大小是214.7 GB,/dev/sda1,sda2,sda3是从这块磁盘上划出来的物理分区(PV),其中sda2上面挂载着/ ;/home;swat;/tmp等等挂载点。一共分配了50G左右的容量。sda1是boot分区,200m。

去掉sda1,sda2之后,还剩122G空间,下面就要把这100多G添加到现有逻辑分区当中去

首先看一下现在的硬盘结构

下面从122G剩余空间中划出一个新的物理分区,使用fdisk

fdisk /dev/sda

输入m获得帮助

命令操作a   toggle a bootable flagb   edit bsd disklabelc   toggle the dos compatibility flagd   delete a partitiong   create a new empty GPT partition tableG   create an IRIX (SGI) partition tablel   list known partition typesm   print this menun   add a new partitiono   create a new empty DOS partition tablep   print the partition tableq   quit without saving changess   create a new empty Sun disklabelt   change a partition's system idu   change display/entry unitsv   verify the partition tablew   write table to disk and exitx   extra functionality (experts only)

输入n新建一个分区,一般使用默认起始位置,然后输入一个大小,最后输入w保存并写入分区表

命令(输入 m 获取帮助):n
Partition type:p   primary (2 primary, 0 extended, 2 free)e   extended
Select (default p): p
分区号 (3,4,默认 3):3
起始 扇区 (180774912-419430399,默认为 180774912):
将使用默认值 180774912
Last 扇区, +扇区 or +size{K,M,G} (180774912-419430399,默认为 419430399):+10GB
分区 3 已设置为 Linux 类型,大小设为 9.3 GiB命令(输入 m 获取帮助):w
The partition table has been altered!Calling ioctl() to re-read partition table.WARNING: Re-reading the partition table failed with error 16: 设备或资源忙.
The kernel still uses the old table. The new table will be used at
the next reboot or after you run partprobe(8) or kpartx(8)
正在同步磁盘。

然后运行

partprobe /dev/sda

才能更新分区表,然后再观察磁盘的分配情况,新的10GB分区就已经分出来了。如果不执行这句,那么跟没分区一样,是无法mount的,只能重启电脑才能失效。所以一定要执行。

注意此时的分区类型还不是LVM(运行fdisk发现id不是8e),需要改成LVM。(注意这一步也可以在上面fdisk划分新分区时使用t命令输入8e完成)

改完以后要注意,如果“内容”这一项不是“LVM2物理卷(LVM2 001)”那么在下面想VG中添加物理卷(PV)时很有可能找不到这个卷。这种情况一般是之前曾经格式化过的磁盘会有这种问题。
 

[root@localhost ~]# fdisk -l磁盘 /dev/sda:214.7 GB, 214748364800 字节,419430400 个扇区
Units = 扇区 of 1 * 512 = 512 bytes
扇区大小(逻辑/物理):512 字节 / 512 字节
I/O 大小(最小/最佳):512 字节 / 512 字节
磁盘标签类型:dos
磁盘标识符:0x0001b91a设备 Boot      Start         End      Blocks   Id  System
/dev/sda1   *        2048      411647      204800   83  Linux
/dev/sda2          411648   180774911    90181632   8e  Linux LVM
/dev/sda3       180774912   200306687     9765888   83  Linux

然后物理分区就只做好了,下面我们只需把这个新的物理分区加入到rhel这个VG中,只有划分到VG中,才可以实现某个挂载点的扩容,扩容之后,一个挂载点就可以使用两块或者更多物理卷(PV)或者物理硬盘,解决某个挂载点容量不足的问题。

[root@oa-app ~]# vgextend rhel /dev/sda3
WARNING: ext4 signature detected on /dev/sda3 at offset 1080. Wipe it? [y/n]: yWiping ext4 signature on /dev/sda3.Physical volume "/dev/sda3" successfully createdVolume group "rhel" successfully extended

执行完上面的命令之后,磁盘管理的“内容”这一项也会变成“LVM2物理卷(LVM2 001)”

然后对lv进行扩容

lv扩容:
第一种方法:直接增大5G,写“+5G”
1.lv扩容5G
lvresize -L +5G /dev/mapper/rhel-root2.文件系统大小变更
resize2fs /dev/mapper/rhel-root第二种方法:原来是10G,增大5G就是“15G”
1.lv扩容到15G
lvresize -L 15G /dev/mapper/rhel-root2.文件系统大小变更
resize2fs  /dev/mapper/rhel-root
注:以上的lvresize命令操作也可以通过lvextend命令实现。//刷新下刚挂载的分区 用resize2fs后面加lvm 设备路径   --如果没有生效就执行以下命令
xfs_info /dev/mapper/rhel-root
xfs_growfs /dev/mapper/rhel-root

不需要杀死进程。

然后可以使用df -h看看剩余空间有没有增多

扩容比较容易,/home这个挂载点也可以缩减,但是缩减就比较麻烦了,首先要umount挂载点/home,umount之前要把所有读写/home的进程都杀死,还得把所有硬盘监控软件停止。才能够缩减。所以执行缩减操作一般会中断当前的服务。缩减之后原来逻辑分区所占的物理位置会分割成两块物理区间,给多个逻辑分区缩减那么物理硬盘就会变的稀碎稀碎的,所以一般不推荐缩减。

这篇关于RedHat7 LVM分区方案实现挂载点无缝扩容(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter