linux學(xué)習(xí)日記十二 磁盤配額(quota)

磁盤配額(quota)比較常用的幾個情況是:
* 針對WWW server,例如:每個人的網(wǎng)頁空間的容量限制
* 針對mail server,例如:每個人的郵件空間限制
* 針對file server:每個人最大的可用網(wǎng)絡(luò)硬盤空間(教學(xué)環(huán)境中比較常見)
上面的是針對網(wǎng)絡(luò)服務(wù)的設(shè)計,如果是針對linux系統(tǒng)主機上面的設(shè)置,用途有下面這些:
* 限制某一用戶組最大磁盤配額,可用設(shè)置普通用戶組和VIP用戶組,有點類似會員制,VIP用戶相應(yīng)的磁盤空間大小比較大些,普通用戶想成為VIP,嘿嘿,交會費就行。
* 限制某一用戶磁盤配額,在對用戶組進(jìn)行限制后,繼續(xù)對該用戶組的每個用戶進(jìn)行設(shè)置,可以使用戶組下有更公平的分配。
* 以Link方式使郵件可以作為限制的配額(更改/var/spool/mail這個路徑)
====Quota的規(guī)范設(shè)置選項====
* 限制文件數(shù)量或者容量(inode或者block),以block設(shè)置為常見
* soft/hard,hard > soft,超過soft后,在grace time(寬限時間)內(nèi)登陸系統(tǒng)后會給出磁盤爆滿的警告
* 會倒計時的寬限時間 grace time,如果過了這個時間還沒降到比soft低,直接鎖定磁盤使用,并且hard減少為soft值。
坐而言不如起而行,先來設(shè)計一個實際的quota例子:
* 五個人的賬號分別為user1,user2,user3,user4,user5,密碼都是123456,初始用戶組都為quotagroup,其他賬號屬性為默認(rèn)。
* 賬號的磁盤容量限制:五個用戶都能夠取得300MB的磁盤使用量(hard),文件數(shù)量不予限制。此外,只要容量超過250MB時候給予警告(soft)
* 用戶組的限額:由于我的系統(tǒng)里面可能還有其他用戶存在,我僅承認(rèn)quotagroup這個組最多使用1GB的容量。也就是說,如果user1,user2,user3都用了280MB的空間,那么user4,user5就只能使用1000MB – 280MB*3 = 160MB的空間了。
* 寬限日期:14天,達(dá)到250MB的soft值后,14天內(nèi)給予警告,如果14天內(nèi)磁盤容量還沒降到比250MB低,直接鎖定用戶。丫的叫你放電影到硬盤上又不刪。
建立5個賬號的shell腳本:
#!/bin/bash
# 使用script新建實驗quota所需的環(huán)境
groupadd quotagroup
for username in user1 user2 user3 user4 user5
do
useradd -g quotagroup $username
echo "123456" | passwd --stdin $username
done
接下來實踐下quota流程:
# df -h /home
文件系統(tǒng) 容量 已用 可用 已用% 掛載點
/dev/sda3 69G 4.4G 62G 7% /
因為我用的虛擬機,自動被分區(qū),只有一個根分區(qū)/掛載sda3文件系統(tǒng),所以我會針對/來進(jìn)行,不過一般來講不建議直接在/下面設(shè)置quota。
# mount | grep ‘\s/\s’
/dev/sda3 on / type ext4 (rw,relatime,seclabel,user_xattr,barrier=1,data=ordered)
通過查看/dev/sda3的數(shù)據(jù)知道是哦那個ext4文件系統(tǒng),那么肯定支持quota
修改配置文件/etc/fstab,讓/支持quota:
UUID=2f08675e-289a-404a-a13e-4802dec910e9 / ext4 defaults,usrquota,grpquota 1 1
重點在上面粗體顯示的usrquota,grpquota
# umount / (我勒個擦,根目錄你怎么umount,還是重啟吧)
# mount -a
# mount | grep “\s/\s”
/dev/sda3 on / type ext4 (rw,relatime,seclabel,user_xattr,barrier=1,data=ordered,usrquota,grpquota)
看到了吧,可以針對用戶組和用戶進(jìn)行磁盤配額了。
====新建quota配置文件====
# quotacheck [-avugfM] [/mount_point]
-a:掃描所有在/etc/mtab內(nèi),含有quota支持的文件系統(tǒng),加上此參數(shù)后,后面的/mount_point就不用寫了
-u:針對用戶掃描文件與目錄使用情況,會新建aquota.user
-g:針對用戶組掃描文件與目錄使用情況,會新建aquota.group
-v:顯示掃描過程信息
-f:強制掃描文件系統(tǒng),并寫入quota配置文件(危險,慎用)
-M:強制以讀寫方式掃描文件系統(tǒng),只有在特殊情況下才會使用。
實際上只需要記住前面四個參數(shù) -augv即可。
# ll -d /a*
-rw——-. 1 root root 8192 10月 27 02:06 /aquota.group
-rw——-. 1 root root 7168 10月 27 02:06 /aquota.user
不要手動去修改這兩個quota配置文件啊,這個是quota自己去更新的。
====quota啟動、關(guān)閉與限制值的設(shè)置====
# quotaon [-avug] <===啟動quota服務(wù)
# quotaon [-vug] /mount_point
上面的參數(shù)跟之前的一模一樣,這個命令只需要執(zhí)行一次,下次系統(tǒng)啟動后會自動再執(zhí)行的
# quotaoff [-a] <===關(guān)閉quota服務(wù)
# quotaoff [-ug] /mount_point
# edquota [-u username] [-g groupname] <===編輯quota的寬限值
# edquota -t <===修改寬限時間
# edquota -p 范本賬號 -u 新賬號
這些都很簡單,不解釋
# edquota -u user1
Disk quotas for user user1 (uid 1002):
Filesystem blocks soft hard inodes soft hard
/dev/sda3 28 0 0 8 0 0
解釋下這七個字段:
1,文件系統(tǒng),或者是partition
2,磁盤容量(blocks):這個是quota自己自動算出來的,單位為KB,不要改動它
3,soft:磁盤容量(block)的soft限制值,單位為KB
4,hard:block的hard限制值,單位為KB
5,文件數(shù)量(inodes):這個也是quota自己自動算出來的,單位為個,不要改動它
6,soft:inode的soft值
7,hard:inode的hard值
我把它修改成如下的:
Disk quotas for user user1 (uid 1002):
Filesystem blocks soft hard inodes soft hard
/dev/sda3 28 250000 300000 8 0 0
注意:我用的1000去近似1024,方便點,其實真正的250MB = 250 * 1024KB,這么說你了解麼 o(╯□╰)o
還有其他四個用戶,直接參考copy user1的設(shè)置就可以了。
# edquota -p user1 -u user2
# edquota -p user1 -u user3
# edquota -p user1 -u user4
# edquota -p user1 -u user5
更改用戶組的quota限額:
# edquota -g quotagroup
Disk quotas for group quotagroup (gid 1002):
Filesystem blocks soft hard inodes soft hard
/dev/sda3 140 900000 1000000 35 0 0
最后,將寬限時間改成14天吧:
# 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 14days 7days
到這步,所有的設(shè)置都已經(jīng)完成,接下來驗收成果:
====quota限制值的報表====
單一用戶/用戶組的quota報表:
# quota [-uvs] username列表
# quota [-gvs] groupname列表
-u:后接用戶名,不填表示當(dāng)前用戶
-g:后接用戶組
-v:顯示每個用戶或者用戶組在文件系統(tǒng)中的quota值
-s:使用好看的單位,比如M之類的
# quota -uvs user1 user2
Disk quotas for user user1 (uid 1002):
Filesystem space quota limit grace files quota limit grace
/dev/sda3 28K 245M 293M 8 0 0
Disk quotas for user user2 (uid 1003):
Filesystem space quota limit grace files quota limit grace
/dev/sda3 28K 245M 293M 8 0 0
針對整個文件系統(tǒng)的報表:
# repquota -a [-vugs]
-a:直接到/etc/mtab查詢具有quota標(biāo)志的文件系統(tǒng),并報告quota結(jié)果
-v:輸出的數(shù)據(jù)將含有文件系統(tǒng)相關(guān)的詳細(xì)信息
-u:顯示出用戶的quota限制(這個是默認(rèn)值)
-g:顯示個別用戶組的quota限制值
-s:使用K,M,G的單位顯示
測試下實際效果:
# su – user1
# dd if=/dev/zero of=bigfile bs=1M count=270
# repquota -auv
dd if=/dev/zero of=bigfile2 bs=1M count=300
dd: 正在寫入”bigfile2″: 超出磁盤限額
記錄了23+0 的讀入
記錄了22+0 的寫出
24047616字節(jié)(24 MB)已復(fù)制,0.648835 秒,37.1 MB/秒
# du -sk
300000 . <===果然到了極限
[user1@(none) ~]$ ll
總用量 299968
-rw-r–r–. 1 user1 quotagroup 283115520 10月 27 02:42 bigfile
-rw-r–r–. 1 user1 quotagroup 24047616 10月 27 02:44 bigfile2
當(dāng)用戶超過了soft,然后再寬限日期又沒有刪除空間,導(dǎo)致用戶的hard變成了原來的soft,用戶再也使用不了磁盤,那么怎么辦呢。當(dāng)然是進(jìn)去刪除文件就行了啊。不過很多用戶不知道怎么回事,最好在用戶超過限額(soft)后給用戶發(fā)警告信:
# warnquota (fedora上面沒有這個命令,囧?。?/p>
==== 不改動既有系統(tǒng)的quota實例(link方式)====
如果/var/spool/mail不是一個獨立分區(qū),你想讓用戶郵件信箱與主文件夾的總體 磁盤使用量固定,但/home是單獨的文件系統(tǒng),跟/var/spool/mail不一樣。
可以這樣解決:
1,將/var/spool/mail這個目錄整個完整的移動到/home下面
2,建立連接 # ln -s /home/mail /var/spool/mail,那么現(xiàn)在所有往/var/spool/mail里面放的數(shù)據(jù)全部放到/home/mail里面去了。
3,將/home/進(jìn)行quota限額設(shè)置
注意,進(jìn)行以上設(shè)置的時候,可能需要關(guān)閉SELinux
====軟件磁盤陣列(Software RAID)====
請參考下一篇文章。哈哈 ……+……
===================================END==============================
相關(guān)文章
Fedora Linux 42 穩(wěn)定版發(fā)布: 帶來大量新功能和軟件更新
Fedora 42昨日發(fā)布,這是 Red Hat 贊助開發(fā)的杰出前沿 Linux 發(fā)行版的最新版,包含大量新功能和軟件更新,使其成為 2025 年上半年發(fā)布的一款出色的 Linux 操作系統(tǒng)之一,內(nèi)2025-04-16如何在Linux查看硬盤信息? 查看Linux硬盤大小類型和硬件信息的5種方法
使用Linux系統(tǒng)的過程中,查看和了解硬盤信息是非常重要的工作,尤其是對于系統(tǒng)管理員而言,那么在Linux系統(tǒng)中如何查看硬盤信息?以下是具體內(nèi)容介紹2025-03-12如何在 Linux 中查看 CPU 詳細(xì)信息? 3招輕松查看CPU型號、核心數(shù)和溫度
在日常運維工作中,獲取 CPU 信息是系統(tǒng)運維管理員常見的工作內(nèi)容,無論是為了性能調(diào)優(yōu)、硬件升級還是僅僅滿足好奇心2025-03-11什么是 Arch Linux? 獨樹一幟的Arch Linux發(fā)行版分析
Arch Linux是為簡化,優(yōu)化,現(xiàn)代化,實用主義,用戶中心和多功能性而創(chuàng)建Linux發(fā)行版,究竟是什么讓 Arch 與眾不同?下面我們就來簡要解讀2025-02-19如何在Linux環(huán)境下制作 Win11裝機U盤?
一直用的linux辦公,想要將筆記本電腦從 Linux 系統(tǒng)切換回 Windows 11,我們可以制作一個win11裝機u盤,詳細(xì)如下2025-02-17Rsnapshot怎么用? 基于Rsync的強大Linux備份工具使用指南
Rsnapshot 不僅可以備份本地文件,還能通過 SSH 備份遠(yuǎn)程文件,接下來詳細(xì)介紹如何安裝、配置和使用 Rsnapshot,包括創(chuàng)建每小時、每天、每周和每月的本地備份,以及如何進(jìn)2025-02-06Linux Kernel 6.13發(fā)布:附更新內(nèi)容及新特性解讀
Linux 內(nèi)核 6.13 正式發(fā)布,新版本引入了惰性搶占支持,簡化內(nèi)核搶占邏輯,通過減少與調(diào)度器相關(guān)的調(diào)用次數(shù),讓內(nèi)核在運行時表現(xiàn)更優(yōu),從而提高效率2025-01-23五大特性引領(lǐng)創(chuàng)新! 深度操作系統(tǒng) deepin 25 Preview預(yù)覽版發(fā)布
今日,深度操作系統(tǒng)正式推出deepin 25 Preview版本,該版本集成了五大核心特性:磐石系統(tǒng)、全新DDE、Treeland窗口合成器、AI For OS以及Distrobox子系統(tǒng)2025-01-18Linux Mint Xia 22.1重磅發(fā)布: 重要更新一覽
Beta 版 Linux Mint“Xia” 22.1 發(fā)布,新版本基于 Ubuntu 24.04,內(nèi)核版本為 Linux 6.8,這次更新帶來了諸多優(yōu)化和改進(jìn),進(jìn)一步鞏固了 Mint 在 Linux 桌面操作系統(tǒng)領(lǐng)域的2025-01-16LinuxMint怎么安裝? Linux Mint22下載安裝圖文教程
Linux Mint22發(fā)布以后,有很多新功能,很多朋友想要下載并安裝,該怎么操作呢?下面我們就來看看詳細(xì)安裝指南2025-01-16