如何配置Ext4的磁盘配额?

Linux基础

1 基础知识

1.1 Disk Quota的概念

Disk Quota用于合理分配有限的磁盘使用空间

1.2 Disk Quota的配置方法

1.2.1 按空间和数量限额

– 用量配额(块配额),即限制可用空间量
– 文件配额(inode配额),即限制创建文件和目录的数量

1.2.2 按软硬限额

– 软配额,达到配额系统给予用户警告并不会采用限额行动
– 硬配额,达到配额系统拒绝用户保存数据
注:某些系统对硬配额有宽限时间(所以并非绝对)

1.2.3 限额的方式

– 根据项目ID限额
– 根据用户ID限额
– 根据用户组限额

1.2.4 项目或目录限额

– ext4、XFS、f2fs、ZFS、Lustre等文件系统支持目录定义块或inode限额
– 管理员首先需要向目录的文件添加项目ID以建立项目标识
– 管理员然后需要定义包含项目标识目录的配额以建立配额限制

1.3 支持配额的系统

– Unix系统,如AIX(使用JFS或JFS2文件系统)
– Linux系统(使用ext3、ext4、ext2、XFS文件系统)
– Solaris(使用UFS或ZFS文件系统)
– Windows 2000以后的系统

1.4 常见的Unix磁盘配额程序

– quota,显示与用户的文件系统用户配额
– edquota,编辑文件系统的用户配额
– setquota,为文件系统设置磁盘配额
– repquota,总览文件系统的配合
– quotacheck,文件系统配额一致性检查器
– /etc/fstab(Linux)或/etc/vfs/tab(Solaris),文件系统默认参数列表(包括配额状态)

2 最佳实践

2.1 安装Quota工具

dnf install -y quota

2.2 启用文件系统的配额

2.2.1 卸载文件系统

umount /dev/mapper/ds-data 

2.2.2 设置文件系统Quota

tune2fs -O quota /dev/mapper/ds-data
tune2fs -Q usrquota,grpquota,prjquota /dev/mapper/ds-data

另外,如果分区没有数据,可以直至使用如下命令格式化处理(可选操作且危险的操作,请谨慎选择使用),

mkfs.ext4 -O quota -E quotatype=usrquota:grpquota:prjquota /dev/mapper/ds-data 

2.2.3 测试系统挂载

mount -o prjquota /dev/mapper/ds-data /data/
umount /data

2.2.4 重新挂载文件系统以启用配额

blkid /dev/mapper/ds-data

可见如下显示,

/dev/mapper/ds-data: UUID="627ae760-3780-4357-8c14-fdb925cdf732" TYPE="ext4"

使用如下命令修改配置,

vim /etc/fstab

修改如下配置,

UUID=627ae760-3780-4357-8c14-fdb925cdf732 /data ext4 defaults,usrquota,grpquota,prjquota 0 0

然后,你需要重载服务使配置生效,然后挂载所有配置,

systemctl daemon-reload
mount -a

另外,以上挂载即已经在分区启用配额,因此如下命令无需再执行

quotaon -vugP /data
quotaon /data

2.3 设置项目配额

2.3.1 声明目录的对应项目ID

echo "00001:/data/ftp/ftpUser01" >> /etc/projects

需要注意的是,
– 冒号前面使用无符号长整型声明“project ID”即项目ID(取值范围0~4294967295)
– 冒号后面使用文件夹路径声明“IDprojected-controlled directory”即项目目录
根据上面的配置要求,你需要手动创建项目ID对应的目录,

mkdir -p /data/ftp/ftpUser01/myhome

2.3.2 声明项目ID的对应项目名称

echo "ftpUser01:00001" >> /etc/projid

需要注意的是,
– 冒号前面使用任意字符串声明“project name”即项目名称,本范例使用ftp的用户名称即“ftpUser01”作为项目名称
– 冒号后面声明“project ID”即项目ID
根据上面的配置要求,你需要手动创建项目ID对应的目录以及声明目录所属的项目ID,同时需要将用户上传目录标记为父目录,

chattr -p 1 /data/ftp/ftpUser01/myhome
chattr +P /data/ftp/ftpUser01/myhome
lsattr -p /data/ftp/ftpUser01

2.3.3 设置项目的配额

edquota -P ftpUser01

以下命令定义项目“ftpUser01”的配额,可见如下显示,

Disk quotas for user will (uid 500):
  Filesystem                   blocks       soft       hard     inodes     soft     hard
  /dev/mapper/ds-data             816    1030000    1031711        102  1030000  1031711

以上配置解析如下,
– 列“Filesystem”声明启用配额的文件系统名称
– 列“blocks”声明当前用户使用的块数目
– 列“soft”声明该用户的blocks软限制(“0”则无限制)
– 列“hard”声明该用户的blocks硬限制(“0”则无限制)
– 列“inodes”声明当前用户使用的块数目
– 列“soft”声明该用户的inodes软限制(“0”则无限制)
– 列“hard”声明该用户的inodes硬限制(“0”则无限制)
另外,快捷的设置方法范例如下,

setquota -P ftpUser01 1030000 1031711 1030000 1031711 /dev/mapper/ds-data

2.3.4 验证项目配额

quota -vP ftpUser01

2.3.5 查看配额

quota -s -P ftpUser01
repquota -P /data/

2.4 设置用户配额

2.4.1 根据用户名称设置配额

edquota -u will

以下命令定义用户“will”的配额,可见如下显示,

Disk quotas for user will (uid 500):
  Filesystem                   blocks       soft       hard     inodes     soft     hard
  /dev/mapper/ds-data             816    1030000    1031711        102  1030000  1031711

以上配置解析如下,
– 列“Filesystem”声明启用配额的文件系统名称
– 列“blocks”声明当前用户使用的块数目
– 列“soft”声明该用户的blocks软限制(“0”则无限制)
– 列“hard”声明该用户的blocks硬限制(“0”则无限制)
– 列“inodes”声明当前用户使用的块数目
– 列“soft”声明该用户的inodes软限制(“0”则无限制)
– 列“hard”声明该用户的inodes硬限制(“0”则无限制)
另外,快捷的设置方法范例如下,

setquota -u will 1030000 1031711 1030000 1031711 /dev/mapper/ds-data

另外,如果需要查询当前分区的Inode数量,请使用如下命令,

df -i

可见如下显示,

Filesystem            Inodes   IUsed   IFree IUse% Mounted on
#...
/dev/mapper/ds-data  2621440      13 2621427    1% /data

另外,如果需要查询当前分区的block数量,请使用如下命令,

df -a

可见如下显示,

Filesystem           1K-blocks      Used Available Use% Mounted on
#...
/dev/mapper/ds-data   20634236    176220  19409852   1% /data

另外,如果需要查询当前分区的大小,请使用如下命令,

df -h

可见如下显示,

Filesystem            Size  Used Avail Use% Mounted on
#...
/dev/mapper/ds-data    20G  173M   19G   1% /data

所以,根据以上命令的结果,大概1G的block数量是“20634236block/20G=1031711.8block”

2.4.2 查询用户配额

quota -u will

可见如下显示,

Disk quotas for user will (uid 500):
     Filesystem  blocks   quota   limit   grace   files   quota   limit   grace
/dev/mapper/ds-data
                 354872  1030000 1031711           44166  1030000 1031711

2.4.3 测试配额(仅供参考,请根据实际情况修改)

mkdir /data/will
cp /var/log/messages /data/will/
chown will:will -R /data/will

以上创建文件后,使用如下命令循环复制测试文件,

su - will
cd /data/will
for i in `seq -w 1 1000000`; do cp -rp messages copy-test-$i; done

另外,由于创建的文件比较多,可使用如下命令浏览和清除,

cd /data/will
find . -name \*copy-test-\* -exec ls -l {} \;
find . -name \*copy-test-\* -exec rm -f {} \;

2.5 设置用户组配额

2.5.1 根据组名称设置配额

edquota -g will

以下命令定义组“will”的配额,可见如下显示,

Disk quotas for group will (gid 500):
  Filesystem                   blocks       soft       hard     inodes     soft     hard
  /dev/mapper/ds-data          769280   20630000   20634236      95732  2620000  2621440

以上配置解析如下,
– 列“Filesystem”声明启用配额的文件系统名称
– 列“blocks”声明当前组使用的块数目
– 列“soft”声明该组的blocks软限制(“0”则无限制)
– 列“hard”声明该组的blocks硬限制(“0”则无限制)
– 列“inodes”声明当前组使用的块数目
– 列“soft”声明该组的inodes软限制(“0”则无限制)
– 列“hard”声明该组的inodes硬限制(“0”则无限制)
另外,快捷的设置方法范例如下,

setquota -g will 20630000 20634236 2620000 2621440 /dev/mapper/ds-data

2.5.2 查询组配额

quota -g will

可见如下显示,

Disk quotas for group will (gid 500):
     Filesystem  blocks   quota   limit   grace   files   quota   limit   grace
/dev/mapper/ds-data
                 827200  20630000 20634236          102947  2620000 2621440

参阅文档
=======================
https://en.wikipedia.org/wiki/Disk_quota

没有评论

发表回复

Linux基础
Linux下的常用性能分析工具?

1 前言 一个问题,一篇文章,一出故事。 最近笔者需要整理常用的Linux分析工具,于是整理此文。 …

Linux基础
如何排查硬盘读写慢问题?

1 前言 一个问题,一篇文章,一出故事。 最近笔者需要排查硬盘慢引起的问题,于是整理此文。 2 最佳 …

Linux基础
如何tcpdump实时测量网络吞吐量?

1 前言 一个问题,一篇文章,一出故事。 最近笔者需要实时测量网络的吞吐量,于是整理此文。 2 最佳 …