佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > Linux系統(tǒng)配置 Linux訪問控制列表(ACL)的權(quán)限控制方法

Linux系統(tǒng)配置 Linux訪問控制列表(ACL)的權(quán)限控制方法

熱門標(biāo)簽:電話機(jī)器人搭建 家政服務(wù)網(wǎng)絡(luò) 服務(wù)器配置 百度競(jìng)價(jià)點(diǎn)擊價(jià)格的計(jì)算公式 美團(tuán) 硅谷的囚徒呼叫中心 外呼系統(tǒng) 解決方案

使用擁有權(quán)限控制的Liunx,工作是一件輕松的任務(wù)。它可以定義任何user,group和other的權(quán)限。無論是在桌面電腦或者不會(huì)有很多用戶的虛擬Linux實(shí)例,或者當(dāng)用戶不愿意分享他們之間的文件時(shí),這樣的工作是很棒的。然而,如果你是在一個(gè)大型組織,你運(yùn)行了NFS或者Samba服務(wù)給不同的用戶,然后你將會(huì)需要靈活的挑選并設(shè)置很多復(fù)雜的配置和權(quán)限去滿足你的組織不同的需求。

Linux(和其他Unix等POSIX兼容的操作系統(tǒng))有一種被稱為訪問控制列表(ACL)的權(quán)限控制方法,它是一種權(quán)限分配之外的普遍范式。例如,默認(rèn)情況下你需要確認(rèn)3個(gè)權(quán)限組:owner、group和other。而使用ACL,你可以增加權(quán)限給其他用戶或組別,而不單只是簡(jiǎn)單的"other"或者是擁有者不存在的組別??梢栽试S指定的用戶A、B、C擁有寫權(quán)限而不再是讓他們整個(gè)組擁有寫權(quán)限。

ACL支持多種Linux文件系統(tǒng),包括ext2, ext3, ext4, XFS, Btfrs, 等。如果你不確定你的文件系統(tǒng)是否支持ACL,請(qǐng)參考文檔。

在文件系統(tǒng)使ACL生效

首先,我們需要安裝工具來管理ACL。

Ubuntu/Debian 中:

$ sudo apt-get install acl

CentOS/Fedora/RHEL 中:

# yum -y install acl

Archlinux 中:

# pacman -S acl

出于演示目的,我將使用ubuntu server版本,其他版本類似。

安裝ACL完成后,需要激活我們磁盤分區(qū)的ACL功能,這樣我們才能使用它。

首先,我們檢查ACL功能是否已經(jīng)開啟。

$ mount

你可以注意到,我的root分區(qū)中ACL屬性已經(jīng)開啟。萬一你沒有開啟,你需要編輯/etc/fstab文件,在你需要開啟ACL的分區(qū)的選項(xiàng)前增加acl標(biāo)記。

現(xiàn)在我們需要重新掛載分區(qū)(我喜歡完全重啟,因?yàn)槲也幌雭G失數(shù)據(jù)),如果你對(duì)其它分區(qū)開啟ACL,你必須也重新掛載它。

$ sudo mount / -o remount

干的不錯(cuò)!現(xiàn)在我們已經(jīng)在我們的系統(tǒng)中開啟ACL,讓我們開始和它一起工作。

ACL 范例

基礎(chǔ)ACL通過兩條命令管理:setfacl用于增加或者修改ACL,getfacl用于顯示分配完的ACL。讓我們來做一些測(cè)試。

我創(chuàng)建一個(gè)目錄/shared給一個(gè)假設(shè)的用戶,名叫freeuser

$ ls -lh /

我想要分享這個(gè)目錄給其他兩個(gè)用戶test和test2,一個(gè)擁有完整權(quán)限,另一個(gè)只有讀權(quán)限。

首先,為用戶test設(shè)置ACL:

$ sudo setfacl -m u:test:rwx /shared

現(xiàn)在用戶test可以隨意創(chuàng)建文件夾,文件和訪問在/shared目錄下的任何地方。

現(xiàn)在我們?cè)黾又蛔x權(quán)限給用戶test2:

$ sudo setfacl -m u:test2:rx /shared

注意test2讀取目錄需要執(zhí)行(x)權(quán)限

讓我來解釋下setfacl命令格式:

-m 表示修改ACL。你可以增加新的,或修改存在的ACLu: 表示用戶。你可以使用 g 來設(shè)置組權(quán)限test 用戶名:rwx 需要設(shè)置的權(quán)限。

現(xiàn)在讓我向你展示如何讀取ACL:

$ ls -lh /shared

你可以注意到,正常權(quán)限后多一個(gè)+標(biāo)記。這表示ACL已經(jīng)設(shè)置成功。要具體看一下ACL,我們需要運(yùn)行:

$ sudo getfacl /shared

最后,如果你需要移除ACL:

$ sudo setfacl -x u:test /shared

如果你想要立即擦除所有ACL條目:

$ sudo setfacl -b /shared

最后,在設(shè)置了ACL文件或目錄工作時(shí),cp和mv命令會(huì)改變這些設(shè)置。在cp的情況下,需要添加“p”參數(shù)來復(fù)制ACL設(shè)置。如果這不可行,它將會(huì)展示一個(gè)警告。mv默認(rèn)移動(dòng)ACL設(shè)置,如果這也不可行,它也會(huì)向您展示一個(gè)警告。

總結(jié)

使用ACL讓在你想要分享的文件上擁有更多的能力和控制,特別是在NFS/Samba服務(wù)。此外,如果你的主管共享主機(jī),這個(gè)工具是必備的。謝謝閱讀,希望能幫到大家,請(qǐng)繼續(xù)關(guān)注腳本之家,我們會(huì)努力分享更多優(yōu)秀的文章。

標(biāo)簽:臨沂 防城港 北海 撫州 韶關(guān) 邢臺(tái) 烏蘭察布 南昌

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Linux系統(tǒng)配置 Linux訪問控制列表(ACL)的權(quán)限控制方法》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    册亨县| 吉林省| 安顺市| 平定县| 湖南省| 获嘉县| 宿州市| 桐柏县| 房产| 井研县| 东辽县| 托克逊县| 雅江县| 磐石市| 呈贡县| 潜山县| 张家界市| 滦南县| 高碑店市| 宁城县| 克东县| 常山县| 九江市| 监利县| 海丰县| 兖州市| 固始县| 马尔康县| 呼图壁县| 桐梓县| 应城市| 新巴尔虎右旗| 宜阳县| 呼伦贝尔市| 佳木斯市| 聂拉木县| 新乡县| 丹寨县| 霍城县| 阜新| 河津市|