Linux ACL

来源:http://www.cnblogs.com/sparkdev/archive/2016/05/28/5536868.html
-Advertisement-
Play Games

ACL 是什麼 ACL的全稱是 Access Control List (訪問控制列表) ,一個針對文件/目錄的訪問控制列表。它在UGO許可權管理的基礎上為文件系統提供一個額外的、更靈活的許可權管理機制。它被設計為UNIX文件許可權管理的一個補充。ACL允許你給任何的用戶或用戶組設置任何文件/目錄的訪問權 ...


ACL 是什麼

ACL的全稱是 Access Control List (訪問控制列表) ,一個針對文件/目錄的訪問控制列表。它在UGO許可權管理的基礎上為文件系統提供一個額外的、更靈活的許可權管理機制。它被設計為UNIX文件許可權管理的一個補充。ACL允許你給任何的用戶或用戶組設置任何文件/目錄的訪問許可權。

ACL有什麼用

既然是作為UGO許可權管理的補充,ACL自然要有UGO辦不到或者很難辦到的本事,例如:

  1. 可以針對用戶來設置許可權
  2. 可以針對用戶組來設置許可權
  3. 子文件/目錄繼承父目錄的許可權

檢查是否支持ACL

ACL需要Linux內核和文件系統的配合才能工作,當前我們能見到的大多數Linux發行版本預設都是支持的。但最好還是能夠先檢查一下:

sudo tune2fs -l /dev/sda1 |grep “Default mount options:”
Default mount options:                 user_xattr    acl

我們能夠看到預設情況下(Default mount options:)已經加入 acl 支持了。

如何設置ACL

我們可以使用setfacl和getfacl命令來設置或觀察文件/目錄的acl許可權。

setfacl

參數不多,直接列出來了:

setfacl [-bkRd] [{-m|-x} acl參數] 文件/目錄名
-m :配置後面的 acl 參數給文件/目錄使用,不可與 -x 合用;
-x :刪除後續的 acl 參數,不可與 -m 合用;
-b :移除所有的 ACL 配置參數;
-k :移除預設的 ACL 參數;
-R :遞歸配置 acl;
-d :配置“預設 acl 參數”,只對目錄有效,在該目錄新建的數據會引用此預設值;

getfacl

getfacl 文件/目錄名

實例

針對用戶來設置許可權

先創建一個測試文件test,然後查看其預設的許可權:

touch test
ll test
-rw-r--r--  1 root root        0 May 28 09:04 test
getfacl test
# file: test
# owner: root
# group: root
user::rw-
group::r--
other::r—

 給apache用戶設置讀寫執行test文件的許可權:

setfacl –m u:apache:rwx test

查看test文件屬性的變化:

ll test
-rw-rwxr--+ 1 root root 0 May 28 09:04 test

許可權部分多個了 “+”, 並且與原來(644)也不一樣了。

查看ACL許可權的變化:

getfacl test
...
user:apache:rwx
...
mask::rwx
...

和設置前相比多了user:apache:rwx和 mask::rwx,此時用戶apache已經擁有了讀寫執行test文件的許可權。

針對用戶組來設置許可權

和針對用戶的設置幾乎一樣,只是把小寫的u換成小寫的g就行了。

子文件/目錄繼承父目錄的許可權

這是一個很棒的例子,它能讓我們創建的子文件或者子文件夾繼承父文件夾的許可權設置!

mkdir mydir
ll -d mydir
drwxr-xr-x 2 root root 4096 May 28 09:35 mydir
setfacl –m d:u:apache:rwx mydir

註意參數 d 在這裡起到了決定性的作用。

查看下屬性的變化:

getfacl mydir
...
default:user::rwx
default:user:apache:rwx
default:group::r-x
default:mask::rwx
default:other::r-x

多了些 default開頭的項,在mydir下創建一個新文件試試:

touch mydir/abc
getfacl mydir/abc
...
user:apache:rwx                 #effective:rw-
group::r-x                      #effective:r--
mask::rw-
...

OK, 看上去還不賴,預設情況下apache用戶是可以對這個文件進行讀寫執行操作的。

 

這裡只是簡介的介紹了ACL的概念和一些典型的用法,更多的使用方式請參考幫助文檔。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 首先安裝mongodb 1.下載地址:http://www.mongodb.org/downloads 2.解壓縮到自己想要安裝的目錄,比如d:\mongodb 3.創建文件夾d:\mongodb\data\db、d:\mongodb\data\log,分別用來安裝db和日誌文件,在log文件夾下創 ...
  • 使用mysql二進位方式連接 您可以使用MySQL二進位方式進入到mysql命令提示符下來連接MySQL資料庫。 實例 以下是從命令行中連接mysql伺服器的簡單實例: 在登錄成功後會出現 mysql> 命令提示視窗,你可以在上面執行任何 SQL 語句。 以上命令執行後,登錄成功輸出結果如下: 在以 ...
  • 先把student刪除,再重新插入數據 1、查詢指定鍵db.集合名稱.find({查詢條件},{指定鍵})指定鍵:1表示顯示,0表示不顯示,_id預設顯示 2、各種查詢方式$lt:<$lte:<=$gt:>$gte:>=$ne:!= $in:包含$nin:不包含 $or:或者 null:空值 $ty ...
  • 1.node和NPM是什麼? Node.js® is a JavaScript runtime built on Chrome's V8 JavaScript engine. Node.js uses an event-driven, non-blocking I/O model that make... ...
  • 1:用戶的shell歷史命令保存在home/username/.bash_history中 #!! 執行用戶的上一條命令 #!pw 執行命令歷史中最近一次以pw開頭的命令 2:'*'來匹配零或多個字元 '?’匹配一個字元 #ls -d Day* 列出Day開頭,後面匹配所有字元的目錄 #ls -d ...
  • 轉自:http://blog.csdn.net/scucj/archive/2006/06/29/852181.aspx OCX和DLL的區別 一、關於DLL的介紹 DLL,動態鏈接庫,Dynamic Link Library的縮寫,是一個包含函數和數據的模塊集合,可以被其它應用程式共用的程式模塊。 ...
  • 登錄MySQL: mysql -u root -p db; 如需修改密碼,第一次: mysqladmin -u root password NEWPASSWORD 已設置過: mysqladmin -u root -p 'oldpassword' password newpassword 執行以下命 ...
  • 原來只在server2016上有,現在加入到win0內測版了windows 容器提供了兩種級別的隔離技術,分別是Windows Server container 和Hyper-V Container ,前者通過進程和命名空間隔離技術提供應用程式隔離。 Windows Server 容器與容器主機和該 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...