linux-centos 【parted命令-GPT分区,lvm磁盘管理,xfs——quota磁盘配额管理 】整套操作

本文主要是介绍linux-centos 【parted命令-GPT分区,lvm磁盘管理,xfs——quota磁盘配额管理 】整套操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一 .parted 交互命令的使用
  • 二 .新增硬盘用Parted分区并打上LVM标志
  • 三. 创建pv ,vg , lv ,并设置磁盘配额
    • 3.1格式化分区为xfs文件系统
    • 3.2 挂载xfs系统分区到指定目录,并通过参数uquota,gquota开启文件系统配额。
    • 3.3 xfs_quota 命令的使用
    • 3.4 设置磁盘配额,容量文件限制参数
    • 3.5 切换test1 测试是否磁盘配额成功
  • 四 .为xfs文件系统扩容
    • 4.1 使用命令lvextend为lv 扩容
    • 4.2 使用命令xfs_growfs来对xfs文件系统扩容(这里以block计数)

前言

inux系统一般是作为服务器的,分区采用lvm分区。
通常划分分区工具我们用的比较多是fdisk命令,但是现在由于磁盘越来越廉价,而且磁盘空间越来越大。而fdisk工具他对分区是有大小限制的,它只能划分小于2T的磁盘。现在的磁盘空间已经远远大于2T,有两个方法来解决这个问题:其一是通过卷管理来实现,其二就是通过Parted工具来实现对2T以上磁盘进行分区操作。GPT格式的磁盘相当于原来MBR磁盘中原来保留4个partition table的4*16个字节,只留第一个16个字节,类似于扩展分区,真正的partition table在512字节之后,GPT分区方式没有四个主分区的限制,最多可达到128个主分区。

一 .parted 交互命令的使用

在这里插入图片描述
使用 print 命令可以査看分区表信息,包括硬盘参数、硬盘大小、扇区大小、分区表类型和分区信息。分区信息共有 7 列,分别如下:

Number:分区号。
Start:分区起始位置。这里不再像fdisk那样用柱面表示,使用字节表示更加直观。
End:分区结束位置。
Size:分区大小。
Type:分区类型。
Filesystem:文件系统类型。
标志:分区的标记。

二 .新增硬盘用Parted分区并打上LVM标志

[root@shanan ~]# parted /dev/sdf
GNU Parted 3.1
Using /dev/sdf
Welcome to GNU Parted! Type 'help' to view a list of commands.
(parted) mklabel gpt                        // 设置分区类型为gpt                                   
Warning: The existing disk label on /dev/sdf will be destroyed and all data on
this disk will be lost. Do you want to continue?
Yes/No? yes                                                               
(parted) print
Model: VMware, VMware Virtual S (scsi)
Disk /dev/sdf: 4398GB
Sector size (logical/physical): 512B/512B
Partition Table: gpt
Disk Flags: Number  Start  End  Size  File system  Name  Flags(parted) mkpart primary 0 2T         //primary指分区类型为主分区,0是分区开始位置  2T是结束位置,或者100% 类型做结束位置也可以
Warning: The resulting partition is not properly aligned for best performance.Ignore/Cancel? ignore                                                     
(parted) mkpart primary 2T 4T                                             
(parted) toggle 1 lvm                       //          标记成lvm                                  
(parted) toggle 2 lvm                        //          标记成lvm                                 
(parted) print                         // 打印当前分区,查看分区设置是否正确                                   
Model: VMware, VMware Virtual S (scsi)
Disk /dev/sdf: 4398GB
Sector size (logical/physical): 512B/512B
Partition Table: gpt
Disk Flags: Number  Start   End     Size    File system  Name     Flags1      17.4kB  2000GB  2000GB               primary  lvm2      2000GB  4398GB  2398GB               primary  lvm(parted) quit                   //   完成后用quit命令退出                                       
Information: You may need to update /etc/fstab.Disk /dev/sdf: 4398.0 GB, 4398046511104 bytes, 8589934592 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
Disk label type: gpt
Disk identifier: D3AD40B6-CC44-4C2E-8398-E1AC9FECFFB5#         Start          End    Size  Type            Name1           34   3906250000    1.8T  Linux LVM       primary2   3906250752   8589932543    2.2T  Linux LVM       primary

三. 创建pv ,vg , lv ,并设置磁盘配额

3.1格式化分区为xfs文件系统

注意:xfs被创建后,其size将无法缩小,但可以通过xfs_growfs来增大

[root@shanan ~]# pvcreate /dev/sdf1 /dev/sdf2Physical volume "/dev/sdf1" successfully created.Physical volume "/dev/sdf2" successfully created.
[root@shanan ~]# vgcreate vg01 /dev/sdf1 /dev/sdf2Volume group "vg01" successfully created
[root@shanan ~]# lvcreate -n lv01 -L 3T vg01Logical volume "lv01" created.[root@shanan ~]# mkfs.xfs -f /dev/vg01/lv01                 // 初始化成xfs文件系统
meta-data=/dev/vg01/lv01         isize=512    agcount=4, agsize=201326592 blks=                       sectsz=512   attr=2, projid32bit=1=                       crc=1        finobt=0, sparse=0
data     =                       bsize=4096   blocks=805306368, imaxpct=5=                       sunit=0      swidth=0 blks
naming   =version 2              bsize=4096   ascii-ci=0 ftype=1
log      =internal log           bsize=4096   blocks=393216, version=2=                       sectsz=512   sunit=0 blks, lazy-count=1
realtime =none                   extsz=4096   blocks=0, rtextents=0

3.2 挂载xfs系统分区到指定目录,并通过参数uquota,gquota开启文件系统配额。

创建用户,挂载lv

[root@shanan /]# useradd test1
[root@shanan /]# passwd test1
Changing password for user test1.
New password: 
BAD PASSWORD: The password fails the dictionary check - it is too simplistic/systematic
Retype new password: 
passwd: all authentication tokens updated successfully.
[root@shanan /]# groupadd zhangsan
[root@shanan /]# mount -o uquota,gquota /dev/vg01/lv01 /mnt  //带参数挂载
[root@shanan /]# chmod 777 /mnt             //为文件夹增加权限,方便测试
[root@shanan /]# mount|grep lv01         //确认参数生效
/dev/mapper/vg01-lv01 on /mnt type xfs (rw,relatime,seclabel,attr2,inode64,usrquota,grpquota)   

3.3 xfs_quota 命令的使用

限制值设定方式(配额方案)
命令格式:xfs_quota  -x  -c  "指令"  [挂载点]
-x :专家模式,后续才能加入-c的指定参数
-c :后面加指令xfs_quota -x -c "limit [-ug] b[soft|hard]=N i[soft|hard]=N name"
xfs_quota -x -c "timer [-ug] [-bir] Ndays"
选项与参数:
limit :实际限制的项目,可以针对 user/group 来限制,限制的项目有
bsoft/bhard : block 的 soft/hard 限制值,可以加单位
isoft/ihard : inode 的 soft/hard 限制值
name: 就是用户/群组的名称
timer :用来设定 grace time 的项目喔,也是可以针对 user/group 以及 block/inode 设定xfs_quota查询命令
列出目前系统的各的文件系统,以及文件系统的 quota 挂载参数支持       
xfs_quota   -x   -c  "print"     显示状态信息
列出目前 目录 的所有用户的 quota 限制值xfs_quota -x -c "report -ubih"  目录名
列出目前支持的 quota 文件系统是否有起动了 quota 功能?xfs_quota  -x  -c  "state"
project 的限制 (针对目录限制)1,规范目录、项目名称(project)与项目 IDecho "11(ID标识符):/xfsquota/myquota(目录)" >> /etc/projectsecho "myquotaproject(项目名称自取):11(ID标识符)" >> /etc/projid2,初始化专案名称xfs_quota -x -c "project -s myquotaproject(项目名称)"
注:u > 用户userg > 组groupi > inode限制数量b > block限制大小h > 人性化humanp > 对象proj

3.4 设置磁盘配额,容量文件限制参数

设置磁盘容量软限制为80M,硬限制为100M,文件软限制为80个,硬限制为100个

[root@shanan /]# xfs_quota -x -c 'limit  -u bsoft=80M bhard=100M isoft=80  ihard=100 test1 ' /mnt查看磁盘容量对于用户是否受限制
[root@shanan /]# xfs_quota -c 'quota -uv test1 '  /mnt
Disk quotas for User test1 (1000)
Filesystem              Blocks      Quota      Limit  Warn/Time      Mounted on
/dev/mapper/vg01-lv010      81920     102400   00 [--------] /mnt
查看文件数量是否受限制:[root@shanan /]# xfs_quota -c 'quota -i -uv test1 ' /mnt
Disk quotas for User test1 (1000)
Filesystem               Files      Quota      Limit  Warn/Time      Mounted on
/dev/mapper/vg01-lv010         80        100   00 [--------] /mnt

3.5 切换test1 测试是否磁盘配额成功

[test1@shanan ~]$ dd if=/dev/zero of=/mnt/aa bs=1M count=80```//写入80M文件成功
83886080 bytes (84 MB) copied, 0.0428921 s, 2.0 GB/s
[test1@shanan ~]$ dd if=/dev/zero of=/mnt/ab bs=1M count=80     //在另一个文件写入80M失败,只写入了21M ,就提示磁盘空间不足了,测试成功
dd: error writing ‘/mnt/ab’: Disk quota exceeded
21+0 records in   
20+0 records out
20971520 bytes (21 MB) copied, 0.0151652 s, 1.4 GB/s
[test1@shanan ~]$ 
[test1@shanan mnt]$ touch 1
touch: cannot touch ‘1’: Disk quota exceeded  // 为什么文件夹造不了,原来是没有存储空间导致文件也造不了
[test1@shanan mnt]$ id test1
uid=1000(test1) gid=1000(test1) groups=1000(test1)[test1@shanan mnt]$ rm -rf *    // 清除空间
[test1@shanan mnt]$ touch {1..100}.txt      //重新开始创建文件
[test1@shanan mnt]$ ls
100.txt  14.txt  19.txt  23.txt  28.txt  32.txt  37.txt  41.txt  46.txt  50.txt  55.txt  5.txt   64.txt  69.txt  73.txt  78.txt  82.txt  87.txt  91.txt  96.txt
10.txt   15.txt  1.txt   24.txt  29.txt  33.txt  38.txt  42.txt  47.txt  51.txt  56.txt  60.txt  65.txt  6.txt   74.txt  79.txt  83.txt  88.txt  92.txt  97.txt
11.txt   16.txt  20.txt  25.txt  2.txt   34.txt  39.txt  43.txt  48.txt  52.txt  57.txt  61.txt  66.txt  70.txt  75.txt  7.txt   84.txt  89.txt  93.txt  98.txt
12.txt   17.txt  21.txt  26.txt  30.txt  35.txt  3.txt   44.txt  49.txt  53.txt  58.txt  62.txt  67.txt  71.txt  76.txt  80.txt  85.txt  8.txt   94.txt  99.txt
13.txt   18.txt  22.txt  27.txt  31.txt  36.txt  40.txt  45.txt  4.txt   54.txt  59.txt  63.txt  68.txt  72.txt  77.txt  81.txt  86.txt  90.txt  95.txt  9.txt
[test1@shanan mnt]$ rm -rf *
[test1@shanan mnt]$ touch {1..101}.txt   
touch: cannot touch ‘101.txt’: Disk quota exceeded   // 提示第101个文件造不了 ,测试成功
[test1@shanan mnt]$ ls
100.txt  14.txt  19.txt  23.txt  28.txt  32.txt  37.txt  41.txt  46.txt  50.txt  55.txt  5.txt   64.txt  69.txt  73.txt  78.txt  82.txt  87.txt  91.txt  96.txt
10.txt   15.txt  1.txt   24.txt  29.txt  33.txt  38.txt  42.txt  47.txt  51.txt  56.txt  60.txt  65.txt  6.txt   74.txt  79.txt  83.txt  88.txt  92.txt  97.txt
11.txt   16.txt  20.txt  25.txt  2.txt   34.txt  39.txt  43.txt  48.txt  52.txt  57.txt  61.txt  66.txt  70.txt  75.txt  7.txt   84.txt  89.txt  93.txt  98.txt
12.txt   17.txt  21.txt  26.txt  30.txt  35.txt  3.txt   44.txt  49.txt  53.txt  58.txt  62.txt  67.txt  71.txt  76.txt  80.txt  85.txt  8.txt   94.txt  99.txt
13.txt   18.txt  22.txt  27.txt  31.txt  36.txt  40.txt  45.txt  4.txt   54.txt  59.txt  63.txt  68.txt  72.txt  77.txt  81.txt  86.txt  90.txt  95.txt  9.txt
[test1@shanan mnt]$ 

四 .为xfs文件系统扩容

4.1 使用命令lvextend为lv 扩容

先使用命令lvextend将LV扩展为3.5G(初始容量是3G),然后使用命令xfs_growfs来对xfs文件系统扩容(这里以block计数)

  --- Logical volume ---LV Path                /dev/vg01/lv01LV Name                lv01VG Name                vg01LV UUID                YGTMn3-bgqe-jvi2-I7Lb-tvrl-9ihq-fnX9xpLV Write Access        read/writeLV Creation host, time shanan, 2020-06-30 10:39:09 -0400LV Status              available# open                 0LV Size                3.00 TiBCurrent LE             786432Segments               2Allocation             inheritRead ahead sectors     auto- currently set to     8192Block device           253:2
[root@shanan ~]# lvextend -L +0.5T /dev/vg01/lv01Size of logical volume vg01/lv01 changed from 3.00 TiB (786432 extents) to 3.50 TiB (917504 extents).Logical volume vg01/lv01 successfully resized.
[root@shanan ~]# lvdisplay --- Logical volume ---LV Path                /dev/centos/swapLV Name                swapVG Name                centosLV UUID                xqescb-ES3e-vPQs-47Et-HWtu-0ZVH-aM5ChULV Write Access        read/writeLV Creation host, time localhost, 2020-06-18 08:18:05 -0400LV Status              available# open                 2LV Size                3.62 GiBCurrent LE             928Segments               1Allocation             inheritRead ahead sectors     auto- currently set to     8192Block device           253:1--- Logical volume ---LV Path                /dev/centos/homeLV Name                homeVG Name                centosLV UUID                rgILsR-Q4Jl-dm6s-DoeZ-O18c-kKU2-61NOkG--- Logical volume ---LV Path                /dev/vg01/lv01LV Name                lv01VG Name                vg01LV UUID                YGTMn3-bgqe-jvi2-I7Lb-tvrl-9ihq-fnX9xpLV Write Access        read/writeLV Creation host, time shanan, 2020-06-30 10:39:09 -0400LV Status              available# open                 0LV Size                3.50 TiBCurrent LE             917504Segments               2Allocation             inheritRead ahead sectors     auto- currently set to     8192Block device           253:2[root@shanan ~]# mount /dev/vg01/lv01 /mnt
[root@shanan ~]# df -h
Filesystem               Size  Used Avail Use% Mounted on
/dev/mapper/centos-root   50G  2.2G   48G   5% /
devtmpfs                 1.7G     0  1.7G   0% /dev
tmpfs                    1.8G     0  1.8G   0% /dev/shm
tmpfs                    1.8G  9.7M  1.8G   1% /run
tmpfs                    1.8G     0  1.8G   0% /sys/fs/cgroup
/dev/sda1               1014M  146M  869M  15% /boot
/dev/mapper/centos-home  246G   33M  246G   1% /home
tmpfs                    351M     0  351M   0% /run/user/0
/dev/mapper/vg01-lv01    3.0T   33M  3.0T   1% /mnt

4.2 使用命令xfs_growfs来对xfs文件系统扩容(这里以block计数)

[root@shanan ~]# xfs_growfs /dev/vg01/lv01 -D 0.5T
meta-data=/dev/mapper/vg01-lv01  isize=512    agcount=4, agsize=201326592 blks=                       sectsz=512   attr=2, projid32bit=1=                       crc=1        finobt=0 spinodes=0
data     =                       bsize=4096   blocks=805306368, imaxpct=5=                       sunit=0      swidth=0 blks
naming   =version 2              bsize=4096   ascii-ci=0 ftype=1
log      =internal               bsize=4096   blocks=393216, version=2=                       sectsz=512   sunit=0 blks, lazy-count=1
realtime =none                   extsz=4096   blocks=0, rtextents=0
data blocks changed from 805306368 to 939524096
[root@shanan ~]# df -h          //  经查看成功扩容到3.5T
Filesystem               Size  Used Avail Use% Mounted on
/dev/mapper/centos-root   50G  2.2G   48G   5% /
devtmpfs                 1.7G     0  1.7G   0% /dev
tmpfs                    1.8G     0  1.8G   0% /dev/shm
tmpfs                    1.8G  9.7M  1.8G   1% /run
tmpfs                    1.8G     0  1.8G   0% /sys/fs/cgroup
/dev/sda1               1014M  146M  869M  15% /boot
/dev/mapper/centos-home  246G   33M  246G   1% /home
tmpfs                    351M     0  351M   0% /run/user/0
/dev/mapper/vg01-lv01    3.5T   33M  3.5T   1% /mnt

这篇关于linux-centos 【parted命令-GPT分区,lvm磁盘管理,xfs——quota磁盘配额管理 】整套操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE