Disk quota
From Wikipedia:
- "A disk quota is a limit set by a system administrator that restricts certain aspects of file system usage on modern operating systems. The function of setting quotas to disks is to allocate limited disk-space in a reasonable way."
This article covers the installation and setup of disk quota.
Installation
Install the quota-tools package.
Configuration
Setup the filesystem
Edit fstab to enable the quota mount option(s) on selected file systems, e.g.:
/etc/fstab
/dev/sda3 /home ext4 defaults,usrquota 0 2
To additionally enable the group quota mount option:
/etc/fstab
/dev/sda3 /home ext4 defaults,usrquota,grpquota 0 2
If supported by the kernel and file system it is recommended to use journaled quota instead:
/etc/fstab
/dev/sda3 /home ext4 defaults,usrjquota=aquota.user,jqfmt=vfsv1 0 2
Append grpjquota=aquota.group
to enable group quota.
Remount the partition to apply the change:
# mount -vo remount /home
Create quota index
To create the quota index for /home
:
# quotacheck -cum /home
Append the -g
parameter to also create a group index.
To enable disk quotas for the desired file system:
# quotaon -v /home
To disable disk quotas for the file system:
# quotaoff -v /home
Usage
Enable quota for user/group
Quotas are configured using edquota
(as the root user) that will be opened in the default configured text editor:
# edquota user
Disk quotas for user user (uid 1000): Filesystem blocks soft hard inodes soft hard /dev/sda3 24 0 0 6 0 0
- blocks
- Indicates number of 1k blocks currently used by the user/group.
- soft
- Indicates max number of blocks for the user/group before a warning is issued and grace period countdown begins. If set to "0" (zero) then no limit is enforced.
- hard
- Indicates max number of blocks for the user/group can use. If maximum amount has been reached, no further disk space can be used. If set to "0" (zero) then no limit is enforced.
- inodes
- Indicates the current inodes amount used by the user/group.
- soft
- Indicates the soft inode limit for the user/group.
- hard
- Indicates the hard inode limit for the user/group.
Consider the following configuration for ftpuser1:
# edquota ftpuser1
Disk quotas for user ftpuser1 (uid 1000): Filesystem blocks soft hard inodes soft hard /dev/sda3 24 1000000 1048576 6 0 0
In this case if ftpuser1 uses over 976MB of space a warning will be issued. If the hard limit of 1GB has been reached the user will be unable to write any more data.
See #Specify a grace period to give users a specific amount of time to reduce storage usage when they hit their soft limit.
hard
limit applies to all files written by and for the respective user/group, including temporary files by started applications, which may crash at this point.Specify a grace period
To give current users some time to reduce their file usage, a grace period can be configured. This specifies the allowed time a user/group can exceed their soft limit and while under their hard limit:
# edquota -t
Grace period before enforcing soft limits for users: Time units may be: days, hours, minutes, or seconds Filesystem Block grace period Inode grace period /dev/sda3 7days 7days
The grace period can be set in seconds, minutes, hours, days, weeks or months.
Reports
Shows all configured quotas:
# repquota -a
Shows quotas on a specific partition:
# repquota /home
Show quotas that apply to a user/user group:
# quota -u user
# quota -g group
Copy quota settings
To one or several users
To copy quota settings from user1
to user2
:
# edquota -p user1 user2
To copy quota settings to several other users, append user3
user4
...
To groups
To copy quota settings from group1
to group2
:
# edquota -g -p group1 group2
To all users
The idea is to modify the quota settings for one user and copy the setting to all other users. Set the quota for user1
and apply the quota to users with a UID greater than 999:
# edquota -p user1 $(awk -F: '$3 > 999 {print $1}' /etc/passwd)
Tips and tricks
Quota warnings
The command warnquota
can be used to warn the users about their quota. Configuration is available in /etc/warnquota.conf
.
Stats
The command quotastats
can be used to give more information about the current quota usage:
$ quotastats
Number of dquot lookups: 101289 Number of dquot drops: 101271 Number of still active inodes with quota : 18 Number of dquot reads: 93 Number of dquot writes: 2077 Number of quotafile syncs: 134518740 Number of dquot cache hits: 7391 Number of allocated dquots: 90 Number of free dquots: 2036 Number of in use dquot entries (user/group): -1946