24 Linux 文件及文件權(quán)限

來自 ls -l 的輸出可能包含清單中的第一個字符所顯示的文件和目錄以外的文件系統(tǒng)對象。本教程后面將會看到更多這樣的對象,但就目前而言,只需那些最常見的對象類型。

代碼             對象類型
-                普通文件
d                目錄
l                符號鏈接
c                字符特殊設(shè)備
b                塊特殊設(shè)備
p                FIFO
s                套接字

更改權(quán)限

添加權(quán)限

假設(shè)創(chuàng)建一個 “Hello world” shell 腳本。在首次創(chuàng)建該腳本時,它通常無法執(zhí)行??梢允褂脦?+x選項的 chmod命令來添加執(zhí)行權(quán)限,如:

[ian@attic4-cent ~]$ echo 'echo "Hello world!"'>hello.sh
[ian@attic4-cent ~]$ ls -l hello.sh
-rw-rw-r--. 1 ian ian 20 Aug 8 22:18 hello.sh
[ian@attic4-cent ~]$ ./hello.sh
bash: ./hello.sh: Permission denied
[ian@attic4-cent ~]$ chmod +x hello.sh
[ian@attic4-cent ~]$ ./hello.sh
Hello world!
[ian@attic4-cent ~]$ ls -l hello.sh
-srwxrwxr-x. 1 ian ian 20 Aug 8 22:18 hello.sh

可以通過類似的方式使用 +r設(shè)置讀權(quán)限,使用 +w設(shè)置寫權(quán)限。事實(shí)上,您可以使用 r、w和 x 的任何組合。例如,使用 chmod +rwx會為文件設(shè)置所有讀、寫和執(zhí)行權(quán)限。這種形式的 chmod 會添加還未設(shè)置的權(quán)限。

保持選擇性

您可能在上面的示例中已注意到,我們?yōu)樗姓?、組其他用戶設(shè)置了執(zhí)行權(quán)限。為了更具有選擇性,您可以為模式表達(dá)式添加:

  • 前綴 u來設(shè)置用戶的權(quán)限,
  • 添加前綴 g來為組設(shè)置用戶權(quán)限,
  • 添加前綴 o來為其他用戶設(shè)置權(quán)限。
  • 指定 a會為所有用戶設(shè)置該權(quán)限,這等效于省略它。
    下面的代碼展示了如何向用戶和組添加該 shell 腳本的另一個副本的寫和執(zhí)行權(quán)限。
[ian@attic4-cent ~]$ echo 'echo "Hello world!"'>hello2.sh**
[ian@attic4-cent ~]$ chmod ug+xw hello2.sh**
[ian@attic4-cent ~]$ ls -l hello2.sh
-rwxrwxr--. 1 ian ian 20 Aug 9 06:22 hello2.sh

刪除權(quán)限

有時您需要刪除權(quán)限,而不是添加它們。只需將 + 更改為 -,就可以刪除任何已設(shè)置的指定權(quán)限。下面的代碼展示了如何為其他用戶刪除這兩個 shell 腳本上的所有權(quán)限。

[ian@attic4-cent ~]$ ls -l hello*.sh
-rwxrwxr--. 1 ian ian 20 Aug 9 06:22 hello2.sh
-rwxrwxr-x. 1 ian ian 20 Aug 8 22:18 hello.sh
[ian@attic4-cent ~]$ chmod o-xrw hello*.sh
[ian@attic4-cent ~]$ ls -l hello*.sh
-rwxrwx---. 1 ian ian 20 Aug 9 06:22 hello2.sh
-rwxrwx---. 1 ian ian 20 Aug 8 22:18 hello.sh

您一次可以更改多個文件上的權(quán)限, 可以使用 -R (或 --recursive)選項來遞歸地操作目錄和文件。

設(shè)置權(quán)限

現(xiàn)在您已經(jīng)可以添加或刪除權(quán)限,您可能想知道如何僅設(shè)置一組特定的權(quán)限??梢允褂?= 代替 + 或 -來實(shí)現(xiàn)此操作。要設(shè)置上述腳本上的權(quán)限,以便其他用戶沒有訪問權(quán),可以使用 chmod o= hello,而不是我們用于刪除權(quán)限的命令。
如果您想為用戶、組或其他用戶設(shè)置不同的權(quán)限,可以使用逗號將不同表達(dá)式分開(例如 ug=rwx,o=rx),或者可以使用數(shù)值權(quán)限。

8421進(jìn)制權(quán)限

之前您已使用符號(ugoa 和 rxw)指定權(quán)限。每個組中有 3 種可能的權(quán)限。也可以使用八進(jìn)制數(shù)代替符號來設(shè)置權(quán)限。通過這種方式設(shè)置的權(quán)限最多使用 4 個八進(jìn)制數(shù)。我們在討論屬性時將介紹第 1 個數(shù)。第 2 個書定義用戶權(quán)限,第 3 個數(shù)定義組權(quán)限,第 4 個數(shù)定義其他權(quán)限。
這 3 個數(shù)中的每一個都通過添加想要的權(quán)限設(shè)置來構(gòu)造:讀 (4)、寫 (2) 和執(zhí)行 (1)。
在想要一次設(shè)置所有權(quán)限,而不為每個組提供相同的權(quán)限時,使用數(shù)值權(quán)限非常方便??梢允褂?表 2 作為8421權(quán)限的方便參考。

符號      八進(jìn)制
rwx       7
rw-       6
r-x       5
r--       4
-wx       3
-w-       2
--x       1
---       0

訪問模式和S位程序

思考一個問題:/etc/shadow文件,它無法由普通用戶直接更改,因?yàn)橹挥?root 用戶能啟用寫權(quán)限。但是,在需要更改其密碼時,普通用戶需要能夠以某種方式修改 /etc/shadow。所以,如果用戶無法修改此文件,如何實(shí)現(xiàn)此目的?

root@ubuntu:/home/newer# ls -l /usr/bin/passwd 
-rwsr-xr-x 1 root root 47032 Jan 26  2016 /usr/bin/passwd

suid 和 sgid

Linux 權(quán)限模型有兩種特殊的訪問模式,稱為 suid(設(shè)置用戶 id)和 sgid(設(shè)置組 id)。一個可執(zhí)行程序設(shè)置了 suid 訪問模式時,它運(yùn)行起來就像是由文件的所有者啟動的一樣,而不是由真正啟動它的用戶啟動的。類似地,在設(shè)置 sgid 訪問模式后,該程序運(yùn)行起來就像啟動的用戶屬于該文件的組,而不是他自己的組??蓡为?dú)或同時設(shè)置兩種訪問模式。
請注意,用戶的權(quán)限三元組中的 x被 s 替代。這表明對于這個特定的程序,設(shè)置了 suid 和可執(zhí)行位。所以當(dāng) passwd 運(yùn)行時,它執(zhí)行起來就像具有完整的超級用戶訪問權(quán)的 root 用戶啟動了它,而不是運(yùn)行它的用戶啟動 它。因?yàn)?passwd 使用 root 訪問權(quán)運(yùn)行,所以它可以修改 /etc/passwd。suid 和 sgid 位占用了長目錄清單中針對用戶和組的 x
位。如果該文件是可執(zhí)行的,suid 或 sgid 位(如果已設(shè)置)將顯示為小寫的 s。否則,它們顯示為大寫的 S。
盡管 suid 和 sgid 使用起來很方便,甚至在許多情況下必不可少,但是,如果不在當(dāng)?shù)厥褂眠@些訪問模式,可能破壞系統(tǒng)的安全性。您擁有盡可能少的 suid 程序。passwd命令是為數(shù)不多的必須 為 suid 的程序之一。

設(shè)置 suid 和 sgid

suid 和 sgid 位使用字母 s以符號方式設(shè)置和重新設(shè)置。例如,u+s
設(shè)置 suid 訪問模式,g-s 刪除 sgid 模式。在八進(jìn)制格式中,suid 在第一個(高階)數(shù)中具有值 4,而 sgid 具有值 2。

目錄和 sgid

當(dāng)一個目錄啟用了 sgid 模式時,其中創(chuàng)建的任何文件或目錄都將繼承該目錄的組 ID。這對一組參與同一個項目的人使用的目錄樹特別有用。

下圖 展示了用戶 greg 如何設(shè)置 development 組的所有用戶都可以訪問的一個目錄,以及用戶 jenni 在該目錄中創(chuàng)建一個文件的示例。在完成創(chuàng)建之后,文件 jenni.txt 允許組成員寫入該文件,所以 jenni 使用 chmod g-w
來禁用組寫入功能。

[jenni@attic4-cent ~]$ su - mary
Password:
 [mary@attic4-cent ~]$ **echo "something" >> ~greg/lpi101/jenni.txt**-bash: /home/greg/lpi101/jenni.txt:
 Permission denied
[mary@attic4-cent ~]$ rm ~greg/lpi101/jenni.txt**rm:
remove write-protected regular empty file `/home/greg/lpi101/jenni.txt'? y
[mary@attic4-cent ~]$ **ls -l ~greg/lpi101
total 0

粘滯位

你剛看到了擁有一個目錄的寫權(quán)限的用戶如何刪除其中的文件。這對組項目而言是可以接受的,但它對全局共享的文件空間(比如 /tmp 目錄)而言不太合意。幸運(yùn)的是,有一個相關(guān)的解決方案。
剩余的訪問模式位被稱為粘滯 位。它們在符號上由 t 表示,在數(shù)值上由高階八進(jìn)制數(shù)中的 1 表示。它在一個長目錄清單中顯示在其他用戶的可執(zhí)行標(biāo)志中(最后一個字符),大寫和小寫對 suid 和 sgid 具有相同的含義。
如果這個位是為一個目錄設(shè)置的,它僅允許所有者用戶或超級用戶 (root) 刪除或取消鏈接一個文件。
下面展示了用戶 greg 如何在他的 lpi101 目錄上設(shè)置粘滯位,還表明這個位是為 /tmp 設(shè)置的。

訪問模式摘要

訪問模式    符號      八進(jìn)制
suid      s with u    4000
sgid      s with g    2000
sticky    t           1000

將此信息與之前的權(quán)限信息相結(jié)合,您就可以看到與 greg 的 lpi101 權(quán)限對應(yīng)的完整的八進(jìn)制表示,而且 drwxrwsr-t 的訪問模式為 3775

ls -l 命令不能顯示文件的8421 權(quán)限,可以通過find命令來看看。

[greg@attic4-cent ~]$ find . -name lpi101 -printf "%M %m %f\n"
drwxrwsr-t 3775 lpi101

lsatr 和 chatr

在Linux中,提供了一種方式chatr +i 來鎖定文件,這個時候即使是root,在沒有去掉該屬性之前,也不能對其進(jìn)行操作。

[root@attic4-cent ~]# touch keep.me
[root@attic4-cent ~]# chattr +i keep.me
[root@attic4-cent ~]# lsattr keep.me
----i---------- keep.me
[root@attic4-cent ~]# rm -f keep.me
rm: cannot remove `keep.me': Operation not permitted
[root@attic4-cent ~]# chattr -i keep.me
[root@attic4-cent ~]# rm -f keep.me

文件創(chuàng)建掩碼

創(chuàng)建新文件時,創(chuàng)建進(jìn)程會指定新文件應(yīng)擁有的權(quán)限。通常,請求的模式為 0666,它使該文件可由任何人讀和寫。目錄的模式默認(rèn)情況下通常為 0777。但是,這種寬容性創(chuàng)建會受到一個 umask 值的影響,該值指定用戶想向新創(chuàng)建的文件或目錄自動授予哪些權(quán)限。系統(tǒng)使用 umask 值來減少最初請求的權(quán)限。您可以使用 umask 命令查看 umask 設(shè)置。

請記住,umask 指定哪些權(quán)限應(yīng)授予

[ian@attic4-cent ~]$ umask -S**u=rwx,g=rwx,o=rx
[ian@attic4-cent ~]$ umask u=rwx,g=,o=
[ian@attic4-cent ~]$ umask  0077
[ian@attic4-cent ~]$ touch newfile
[ian@attic4-cent ~]$ **ls -l newfile
-rw-------. 1 ian ian 0 Aug 9 07:09 newfile

新創(chuàng)建的文件的默認(rèn)權(quán)限為 0666,而且 umask 值指定其中哪些位應(yīng)刪除(屏蔽掉)。所以如果您想要執(zhí)行權(quán)限,必須將它顯式添加到文件中。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,646評論 6 533
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,595評論 3 418
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 176,560評論 0 376
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,035評論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,814評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,224評論 1 324
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,301評論 3 442
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,444評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,988評論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,804評論 3 355
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,998評論 1 370
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,544評論 5 360
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,237評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,665評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,927評論 1 287
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,706評論 3 393
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,993評論 2 374

推薦閱讀更多精彩內(nèi)容