quota使用

一、检查系统是否支持

bash 复制代码
grep CONFIG_QUOTA /boot/config*
CONFIG_QUOTA=y
CONFIG_QUOTA_NETLINK_INTERFACE=y
# CONFIG_QUOTA_DEBUG is not set
CONFIG_QUOTA_TREE=y
CONFIG_QUOTACTL=y
CONFIG_QUOTACTL_COMPAT=y

二、安装

bash 复制代码
yum install -y quota

三、配置

3.1 创建磁盘

格式一定要 ext,不能 xfs!!!

bash 复制代码
# 1. 这里新建了一个硬盘
fdisk /dev/sdb
# n 然后回车,最后w就行

# 2. 格式化硬盘,注意这里一定要ext4或者ext3格式,xfs格式是不行的
mkfs.ext4 /dev/sdb1

# 3. 设置挂载格式,这里挂载到/mnt/test下
mkdir /mnt/test
echo "/dev/sdb1 /mnt/test ext4 defaults,usrquota,grpquota 0 0" >> /etc/fstab
mount -a
# mount --o remount / 这个是重新挂载,有时候用得到

3.2 设置配额

bash 复制代码
# 1. 创建用户配额文档
quotacheck -cvug /mnt/test
ls -al /mnt/test/a*

# 2. 设置单个用户的配额,格式: soft hard inode
setquota -u bhlu 10M 10M 0 0 /mnt/test/

# 3. 查看用户配额
edquota -u bhlu

# 4. 将配置复制给其他人
edquota -p bhlu -u test
edquota -u test
# 将bhlu的配额策略复制给多个人可以这样 edquota -p bhlu test01 test02 test03

# 5. 启动配额,quotaon -av也行
quotaon /mnt/test/

# 6. 查看是否启动成功
quotaon -p /mnt/test/
group quota on /mnt/test (/dev/sdb1) is on
user quota on /mnt/test (/dev/sdb1) is on

3.3 测试配额是否成功

bash 复制代码
# 1. 设置一下权限,不然用户没有权限创建文件
chmod 777 /mnt/test

# 2. 进入用户
su - bhlu

# 3. 生成10M文件
dd if=/dev/zero of=/mnt/test/testfile1 bs=1M count=10
ls -lh /mnt/test/testfile1
-rw-rw-r-- 1 bhlu bhlu 10M Jul 13 23:33 /mnt/test/testfile1

# 4. 再次创建一个文件
echo "111" > /mnt/test/testfile2
sdb1: write failed, user block limit reached
-bash: echo: write error: Disk quota exceeded

# 5. 查看是否成功,发现没有数据
ls -lh /mnt/test/testfile2
-rw-rw-r-- 1 bhlu bhlu 0 Jul 13 23:33 /mnt/test/testfile2

# 6. 调整用户配额大小
exit
setquota -u bhlu 20M 20M 0 0 /mnt/test/
edquota -u bhlu

# 7. 再次写入数据
su - bhlu
echo "111" > /mnt/test/testfile3
ls -lh /mnt/test/testfile3
-rw-rw-r-- 1 bhlu bhlu 4 Jul 13 23:37 /mnt/test/testfile3

3.4 关闭配额

bash 复制代码
# 1. 关闭配额
quotaoff -vaug

# 2. 修改/etc/fstab,然后umount就行了

四、总结

上面只是演示 quota 的简单用法,如果还需要更细致的配置,需要查看相关文档。

  • 几个注意点需要注意下
    1. 磁盘的格式,我自己测试 xfs 格式是不行的,ext4 格式可以
    2. 用户的配额,单位都是 KB,一般 softhard 配置是一样的, blocks 可以显示用户已经使用空间大小,inode 是文件节点,我理解是文件数量,尽量设置为 0 即可,也就是不限制
相关推荐
小猿姐10 小时前
唯品会大规模数据库云原生实践:基于 KubeBlocks 管理数千实例的统一运维之路
运维·elasticsearch·云原生
SkyWalking中文站1 天前
认识 Horizon UI · 5/17:3D 基础设施地图
运维·监控·自动化运维
SkyWalking中文站2 天前
认识 Horizon UI · 1/17:SkyWalking 新一代可观测性控制台
运维·前端·监控
雪梨酱QAQ2 天前
Kubeneters HA Cluster部署
运维
江华森2 天前
Spring Cloud 微服务全栈实战:从 Eureka 到 Docker Compose 一文贯通
运维
江华森2 天前
Matplotlib 数据绘图基础入门
运维
江华森2 天前
NumPy 数值计算基础入门
运维
乘云数字DATABUFF6 天前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
荣--8 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森8 天前
动手实战学 Docker — 从零到集群编排完全指南
运维