配置 Linux 的訪問控制列表(ACL)
使用擁有許可權控制的Liunx,工作是一件輕鬆的任務。它可以定義任何user,group和other的許可權。無論是在桌面電腦或者不會有很多使用者的虛擬Linux例項,或者當使用者不願意分享他們之間的檔案時,這樣的工作是很棒的。然而,如果你是在一個大型組織,你執行了NFS或者Samba服務給不同的使用者,然後你將會需要靈活的挑選並設定很多複雜的配置和許可權去滿足你的組織不同的需求。
Linux(和其他Unix等POSIX相容的作業系統)有一種被稱為訪問控制列表(ACL)的許可權控制方法,它是一種許可權分配之外的普遍正規化。例如,預設情況下你需要確認3個許可權組:owner、group和other。而使用ACL,你可以增加許可權給其他使用者或組別,而不單只是簡單的"other"或者是擁有者不存在的組別。可以允許指定的使用者A、B、C擁有寫許可權而不再是讓他們整個組擁有寫許可權。
ACL支援多種Linux檔案系統,包括ext2, ext3, ext4, XFS, Btfrs, 等。如果你不確定你的檔案系統是否支援ACL,請參考文件。
在檔案系統使ACL生效
首先,我們需要安裝工具來管理ACL。
Ubuntu/Debian 中:
$ sudo apt-get install acl
CentOS/Fedora/RHEL 中:
# yum -y install acl
Archlinux 中:
# pacman -S acl
出於演示目的,我將使用ubuntu server版本,其他版本類似。
安裝ACL完成後,需要啟用我們磁碟分割槽的ACL功能,這樣我們才能使用它。
首先,我們檢查ACL功能是否已經開啟。
$ mount
你可以注意到,我的root分割槽中ACL屬性已經開啟。萬一你沒有開啟,你需要編輯/etc/fstab檔案,在你需要開啟ACL的分割槽的選項前增加acl標記。
現在我們需要重新掛載分割槽(我喜歡完全重啟,因為我不想丟失資料),如果你對其它分割槽開啟ACL,你必須也重新掛載它。
$ sudo mount / -o remount
乾的不錯!現在我們已經在我們的系統中開啟ACL,讓我們開始和它一起工作。
ACL 範例
基礎ACL通過兩條命令管理:setfacl用於增加或者修改ACL,getfacl用於顯示分配完的ACL。讓我們來做一些測試。
我建立一個目錄/shared給一個假設的使用者,名叫freeuser
$ ls -lh /
我想要分享這個目錄給其他兩個使用者test和test2,一個擁有完整許可權,另一個只有讀許可權。
首先,為使用者test設定ACL:
$ sudo setfacl -m u:test:rwx /shared
現在使用者test可以隨意建立資料夾,檔案和訪問在/shared目錄下的任何地方。
現在我們增加只讀許可權給使用者test2:
$ sudo setfacl -m u:test2:rx /shared
注意test2讀取目錄需要執行(x)許可權
讓我來解釋下setfacl命令格式:
- -m 表示修改ACL。你可以增加新的,或修改存在的ACL
- u: 表示使用者。你可以使用 g 來設定組許可權
- test 使用者名稱
- :rwx 需要設定的許可權。
現在讓我向你展示如何讀取ACL:
$ ls -lh /shared
你可以注意到,正常許可權後多一個+標記。這表示ACL已經設定成功。要具體看一下ACL,我們需要執行:
$ sudo getfacl /shared
最後,如果你需要移除ACL:
$ sudo setfacl -x u:test /shared
如果你想要立即擦除所有ACL條目:
$ sudo setfacl -b /shared
最後,在設定了ACL檔案或目錄工作時,cp和mv命令會改變這些設定。在cp的情況下,需要新增“p”引數來複制ACL設定。如果這不可行,它將會展示一個警告。mv預設移動ACL設定,如果這也不可行,它也會向您展示一個警告。
總結
使用ACL讓在你想要分享的檔案上擁有更多的能力和控制,特別是在NFS/Samba服務。此外,如果你的主管共享主機,這個工具是必備的。
via: http://xmodulo.com/2014/08/configure-access-control-lists-acls-linux.html
作者:Christopher Valerio 譯者:VicYu 校對:wxy
相關文章
- IOS - ACL (訪問控制列表)iOS
- Redis 6.0 訪問控制列表ACL說明Redis
- 演示:動態訪問控制列表(帶鎖的ACL)
- ora-24247 :網路訪問被訪問控制列表(ACL)拒絕
- Linux Kernel ACL訪問控制漏洞(轉)Linux
- HCNA Routing&Switching之訪問控制列表ACL
- 配置ACL在網路服務中訪問控制
- 網路訪問控制列表ACL(讀懂這篇就基本夠了,後面有配置案例)
- 程式設計實現遍歷ACL訪問控制列表檢查程式訪問許可權程式設計訪問許可權
- 支援 ACL 訪問控制、引入 HOCON 全新配置檔案格式
- 思科路由器反向訪問控制列表配置路由器
- JoomlaACL訪問控制列表OOM
- 如何解決ORACLE11G裡面ORA-24247 網路訪問被訪問控制列表 (ACL) 拒絕 錯誤Oracle
- 用訪問控制列表實現網路單向訪問(轉)
- linux系統ACL控制Linux
- Linux之facl----設定檔案訪問控制列表(詳解)Linux
- Windows原理深入學習系列-訪問控制列表Windows
- jCasbin: 強大的訪問控制、許可權管理框架,支援 ACL, RBAC, ABAC框架
- nginx的高階配置(5)——訪問控制Nginx
- 網路層訪問許可權控制技術 ACL詳解(轉)訪問許可權
- 新手學堂:防火牆概念與訪問控制列表(轉)防火牆
- 類的訪問控制
- 檔案和目錄的訪問控制(2)新增訪問控制
- 如何增強 Linux 核心中的訪問控制安全Linux
- Swift 中的訪問控制Swift
- 使用動態Proxy和Java ACL進行使用者訪問控制機制實現Java
- Linux下FreeTDS訪問MSSQL Server的配置LinuxSQLServer
- Mongodb訪問控制MongoDB
- Flask——訪問控制Flask
- RabbitMQ訪問控制MQ
- Nginx訪問控制Nginx
- Swift 訪問控制Swift
- 基於linux下的selinux強制訪問控制Linux
- 詳解Linux中SSH遠端訪問控制Linux
- Swift的訪問控制講解Swift
- Nginx 對訪問量的控制Nginx
- ABAC訪問控制模型模型
- Windows原理深入學習系列-訪問控制列表-關於安全描述符的補充Windows