0

0

如何设置Linux磁盘配额 xfs_quota限制用户空间

P粉602998670

P粉602998670

发布时间:2025-07-24 12:42:02

|

867人浏览过

|

来源于php中文网

原创

linux系统中,使用xfs文件系统的xfs_quota工具可以限制用户或组的磁盘使用空间。1. 确认挂载选项已启用uquota或gquota,并通过remount或重启生效;2. 使用xfs_quota初始化配额数据库文件.aquota.user;3. 通过limit命令设置用户block和inode的软限与硬限;4. 查看配额报告并设置宽限期;5. 验证配额是否生效。整个过程需依次执行并确保每步成功。

如何设置Linux磁盘配额 xfs_quota限制用户空间

Linux系统中,如果你希望限制某个用户或组的磁盘使用空间,可以使用XFS文件系统的xfs_quota工具。这个工具功能强大、配置灵活,适合在服务器环境中进行磁盘配额管理。

如何设置Linux磁盘配额 xfs_quota限制用户空间

1. 确认文件系统支持并启用quota

XFS只在挂载时支持配额功能,因此第一步要确认你的挂载点是否已经启用了user或group级别的配额。

  • 编辑 /etc/fstab 文件,在对应挂载项的选项里加上 uquota(用户)或 gquota(组),例如:
UUID=xxx /home xfs defaults,uquota 0 0
  • 卸载再重新挂载该分区,或者重启系统使设置生效:
mount -o remount /home
小技巧:可以用 mount | grep home 来查看当前挂载参数是否包含 quota 相关内容。

2. 创建和初始化aquota.user文件

虽然XFS不像ext系列文件系统那样依赖外部的aquota.user文件,但有些操作仍然需要它存在。

  • 使用 xfs_quota 初始化用户配额信息:
xfs_quota -x -c 'initialize' /home

这会在指定挂载点下生成必要的配额数据库文件,比如 .aquota.user

如何设置Linux磁盘配额 xfs_quota限制用户空间

3. 设置用户配额:软限 + 硬限

使用 xfs_quota 命令来设置用户的磁盘空间限制。主要用到 -x(专家模式)和 -c(执行命令)两个参数。

比如,想给用户 testuser 设置硬限制为 5GB,软限制为 4GB:

xfs_quota -x -c 'limit bsoft=4g bhard=5g testuser' /home

这里:

  • bsoft 是软限制,超过后会进入宽限期;
  • bhard 是硬限制,绝对不能突破;
  • /home 是挂载点,根据实际情况修改。

注意:除了空间限制(block),你还可以限制 inode 数量(files):

xfs_quota -x -c 'limit isoft=1000 ihard=1200 testuser' /home

4. 查看配额信息与调整宽限期

你可以随时查看当前用户的配额情况:

Tana
Tana

“节点式”AI智能笔记工具,支持超级标签。

下载
xfs_quota -c 'report' /home

默认报告包括 block 和 inode 的使用情况。

如果设置了软限制,还需要设置宽限期(grace time),否则用户一旦超过软限就无法写入了。

设置宽限期的方法如下:

xfs_quota -x -c 'timer -b 7d' /home

这条命令表示,允许用户在超过软限后有 7天时间 恢复到软限以下。也可以对 inode 设置类似时间。


5. 验证配额是否生效

你可以切换到目标用户账户,尝试复制大文件进去,看看是否真的被限制了。

例如:

su - testuser
dd if=/dev/zero of=testfile bs=1M count=6000

如果设置的是5G硬限制,那么复制到接近5G的时候就会提示“Disk quota exceeded”。


小结

  • XFS的配额是通过挂载选项+命令行工具控制的。
  • 要先开启挂载参数,再设置具体用户的限制。
  • 推荐同时设置软限和宽限期,避免突然中断用户操作。
  • 可以限制block空间和inode数量,两者都要考虑。

基本上就这些。配置起来不复杂,但稍有步骤,注意检查每一步是否成功执行即可。

相关专题

更多
数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

352

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2075

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

347

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

255

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

324

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

410

2023.10.16

vb连接access数据库的方法
vb连接access数据库的方法

vb连接access数据库方法:1、使用ADO连接,首先导入System.Data.OleDb模块,然后定义一个连接字符串,接着创建一个OleDbConnection对象并使用Open() 方法打开连接;2、使用DAO连接,首先导入 Microsoft.Jet.OLEDB模块,然后定义一个连接字符串,接着创建一个JetConnection对象并使用Open()方法打开连接即可。

401

2023.10.16

vb连接数据库的方法
vb连接数据库的方法

vb连接数据库的方法有使用ADO对象库、使用OLEDB数据提供程序、使用ODBC数据源等。详细介绍:1、使用ADO对象库方法,ADO是一种用于访问数据库的COM组件,可以通过ADO连接数据库并执行SQL语句。可以使用ADODB.Connection对象来建立与数据库的连接,然后使用ADODB.Recordset对象来执行查询和操作数据;2、使用OLEDB数据提供程序方法等等。

220

2023.10.19

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.5万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号