Linux中限制用戶訪問權限的3種方法

現在需要限定某個用戶對特定目錄/文件的訪問權限,或者把某個用戶的訪問範圍限制在某個目錄/文件中。現實情況下,還是能遇到這樣的需求的,比如說ubuntu下有多個可登錄用戶,默認情況下,用戶A的工作目錄(一般爲/home/A)對任何其他用戶來說都是可讀的,但是用戶A可能不希望其他用戶(或者某個特定用戶)讀取A的文件。

這裏提出三個解決方案。

第一種:使用chmod更改特定目錄的權限。這能起到限制特定目錄被某些人訪問的作用,限定某個用戶的目的也能達到,但是會誤傷其他用戶。
第二種:使用linux容器,例如lxc。耗費空間,設置稍顯麻煩。
第三種:使用setfacl命令設定訪問控制。

其中,第三個方案是最符合要求的。本文主要講該方案的具體實現,其中根目錄/使用的是ext4文件系統,/home使用的btrfs文件系統。

安裝acl

代碼如下:
sudo apt-get install acl

有資料說是要重啓系統,有的沒有重啓依舊有效。


使用setfacl

以root的身份執行下面的命令:

代碼如下:
# mkdir /home/test
# touch /home/test/foo.txt
# vim /home/test/foo.txt
# ls -ld /home/test/
drwxr-xr-x 1 root root 14 Jan 16 09:46 /home/test/
# ls -ld /home/test/foo.txt 
-rw-r--r-- 1 root root 6 Jan 16 09:46 /home/test/foo.txt

上面的命令在/home目錄下創建目錄test,在test目錄下創建文件foo.txt,並在foo.txt下隨便加了些內容。然後以普通用戶letian的身份訪問foo.txt,可以讀foo.txt。

現在以root身份運行setfacl,使得/home/test目錄及其裏面的文件和目錄不能被letian訪問。

代碼如下:
# setfacl -R -m u:letian:- /home/test/

-R表示遞歸,-m表示修改,u:letian:-表示用戶(user)letian對/home/test沒有任何權限。可以根據需要添加r、w、x及其組合。 我們查看一下test目錄的詳細信息:

代碼如下:
# ls -ld /home/test/
drwxr-xr-x+ 1 root root 14 Jan 16 09:46 /home/test/

文件權限後面出現了一個+號,這說明該文件或者目錄設置了ACL。foo.txt的權限信息後面也會有+號。 然後,以letian的身份訪問該目錄:

代碼如下:

$ ls /home/test
ls: cannot open directory /home/test: Permission denied


使用getfacl

getfacl用來查看對某個目錄/文件設置的acl。

代碼如下:
$ getfacl /home/test
# file: /home/test
# owner: root
# group: root
user::rwx
user:letian:---
group::r-x
mask::r-x
other::r-x

刪除設置的acl

代碼如下:

# setfacl -b /home/test/
# getfacl /home/test
# file: /home/test
# owner: root
# group: root
user::rwx
group::r-x
other::r-x
發佈了21 篇原創文章 · 獲贊 159 · 訪問量 23萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章