Linux chmod命令詳細用法

指令名稱 : chmod
使用權限 : 全部使用者
使用方式 : chmod [-cfvR] [--help] [--version] mode file...

說明 : Linux/Unix 的檔案調用權限分爲三級 : 檔案擁有者羣組其餘。利用 chmod 能夠藉以控制檔案如何被他人所調用。

參數 :
mode : 權限設定字串,格式以下 : [ugoa...][[+-=][rwxX]...][,...],其中

u 表示該檔案的擁有者, g 表示與該檔案的擁有者屬於同一個羣體(group)者, o 表示其餘之外的人, a 表示這三者皆是。

+ 表示增長權限、- 表示取消權限、 = 表示惟一設定權限。

r 表示可讀取,w 表示可寫入,x 表示可執行,X 表示只有當該檔案是個子目錄或者該檔案已經被設定過爲可執行。

-c : 若該檔案權限確實已經更改,才顯示其更改動做
-f : 若該檔案權限沒法被更改也不要顯示錯誤訊息

-v : 顯示權限變動的詳細資料
-R : 對目前目錄下的全部檔案與子目錄進行相同的權限變動(即以遞迴的方式逐個變動)

--help : 顯示輔助說明
--version : 顯示版本

範例 : shell

將檔案 file1.txt 設爲全部人皆可讀取 :
chmod ugo+r file1.txt  spa

將檔案 file1.txt 設爲全部人皆可讀取 :
chmod a+r file1.txt 

將檔案 file1.txt 與 file2.txt 設爲該檔案擁有者,與其所屬同一個羣體者可寫入,但其餘之外的人則不可寫入 :
chmod ug+w,o-w file1.txt file2.txt 

將 ex1.py 設定爲只有該檔案擁有者能夠執行 :
chmod u+x ex1.py 

將目前目錄下的全部檔案與子目錄皆設爲任何人可讀取 :
chmod -R a+r * 

此外chmod也能夠用數字來表示權限如 chmod 777 file
語法爲:chmod abc file

其中a,b,c各爲一個數字,分別表示User、Group、及Other的權限。
r=4,w=2,x=1
若要rwx屬性則4+2+1=7;

若要rw-屬性則4+2=6;
若要r-x屬性則4+1=7。

範例:

chmod a=rwx file  和 chmod 777 file  效果相同

chmod ug=rwx,o=x file  和  chmod 771 file  效果相同

若用chmod 4755 filename可以使此程序具備root的權限 io


chmod 4755和chmod 755的區別

chmod是Linux下設置文件權限的命令,後面的數字表示不一樣用戶或用戶組的權限。

通常是三個數字:

第一個數字表示文件全部者的權限
第二個數字表示與文件全部者同屬一個用戶組的其餘用戶的權限
第三個數字表示其它用戶組的權限。

權限分爲三種: 讀(r=4),寫(w=2),執行(x=1)。綜合起來還有可讀可執行(rx=5=4+1)、可讀可寫(rw=6=4+2)、可讀可寫可執行(rwx=7=4+2+1)。

因此,chmod 755 設置用戶的權限爲:

1.文件全部者可讀可寫可執行
2.與文件全部者同屬一個用戶組的其餘用戶可讀可執行
3.其它用戶組可讀可執行

chmod 4755與chmod 755 的區別在於開頭多了一位,這個4表示其餘用戶執行文件時,具備與全部者至關的權限。

例如:root用戶建立了一個上網認證程序netlogin,若是其餘用戶要上網也要用到這個程序,那就須要root用戶運行chmod 755 netlogin命令使其餘用戶也能運行netlogin。

可是netlogin執行時可能須要訪問一些只有root用戶纔有權訪問的文件,那麼其餘用戶執行netlogin時可能由於權限不夠仍是不能上網。

這種狀況下,就能夠用 chmod 4755 netlogin 設置其餘用戶在執行netlogin也有root用戶的權限,從而順利上網。

ps:對shell腳本設置無效!只對應用程序有效! file

相關文章
相關標籤/搜索