當我們登入系統之後建立乙個檔案總是有乙個預設許可權的,那麼這個許可權是怎麼來的呢?這就是umask幹的事情。umask設定了使用者建立檔案的預設 許可權,它與chmod的效果剛好相反,umask設定的是許可權「補碼」,而chmod設定的是檔案許可權碼。一般可在/etc/profile、/etc/bashrc、$
[home]/.bash_profile、$[home]/.profile或$[home]/.bashrc中設定umask值。具體取決於linux發行版,比如fedora19下要更改自己的umask值,在$[home]/.profile或$[home]/.bash_profile下的增加umask的值覆蓋不了/etc/profile中的配置值的,必須在$[home]/.bashrc下增加umask值才可以永久定義自己的umask值。
umask [選項] [掩碼][1]
該命令用來設定限制新檔案許可權的掩碼。當新檔案被建立時,其最初的許可權由檔案建立掩碼決定。使用者每次註冊進入系統時,umask命令都被執行,並自動設定掩碼改變預設值,新的許可權將會把舊的覆蓋。
選項及其含義如下。
-s:顯示當前的掩碼。
umask是從許可權中「拿走」相應的位,且檔案建立時不能賦予執行許可權。
你的系統管理員必須要為你設定乙個合理的 umask值,以確保你建立的檔案具有所希望的預設許可權,防止其他非同組使用者對你的檔案具有寫許可權。在已經登入之後,可以按照個人的偏好使用umask命 令來改變檔案建立的預設許可權。相應的改變直到退出該shell或使用另外的umask命令之前一直有效。一般來說,umask命令是在/etc /profile檔案中設定的,每個使用者在登入時都會引用這個檔案,所以如果希望改變所有使用者的umask,可以在該檔案中加入相應的條目。如果希望永久 性地設定自己的umask值,那麼就把它放在自己$home目錄下的.profile或.bash_profile或.bashrc檔案中。
umask 命令允許你設定檔案建立時的預設模式,對應每一類使用者(檔案屬主、同組使用者、其他使用者)存在乙個相應的umask值中的數字。對於檔案來說,這一數字的最 大值分別是6。系統不允許你在建立乙個文字檔案時就賦予它執行許可權,必須在建立後用chmod命令增加這一許可權。目錄則允許設定執行許可權,這樣針對目錄來 說,umask中各個數字最大可以到7。
該命令的一般形式為:
umask nnn
其中nnn為umask置000-777。
讓我們來看一些例子。
計算出你的umask值:
可以有幾種計算umask值的方法,通過設定umask值,可以為新建立的檔案和目錄設定預設許可權。下表列出了與許可權位相對應的umask值。
在計算umask值時,可以針對各類使用者分別在這張表中按照所需要的檔案/目錄建立預設許可權查詢對應的umask值。
例如,umask值002 所對應的檔案和目錄建立預設許可權分別為6 6 4和7 7 5。
還有另外一種計算umask值的方法。我們只要記住umask是從許可權中「拿走」相應的位即可。
下表列出了一些umask值及它們所對應的目錄和檔案許可權。
常用的umask值及對應的檔案和目錄許可權
umask值 目錄許可權 檔案許可權
022 7 5 5 6 4 4
027 7 5 0 6 4 0
002 7 7 5 6 6 4
006 7 7 1 6 6 0
007 7 7 0 6 6 0
如果想知道當前的umask 值,可以使用umask命令:
$umask
如果想要改變umask值,只要使用umask命令設定乙個新的值即可:
$ umask 002
確認一下系統是否已經接受了新的u m a s k值:
$umask
002$touch testfile
$ls -l testfile
rw- rw- r--
在使用umask命令之前一定要弄清楚到底希望具有什麼樣的檔案/目錄建立預設許可權。否則可能會得到一些非常奇怪的結果;例如,如果將umask值設定為6 0 0,那麼所建立的檔案/目錄的預設許可權就是0 6 6!
linux命令詳解 umask
當我們登入系統之後建立乙個檔案總是有乙個預設許可權的,那麼這個許可權是怎麼來的呢?這就是umask幹的事情。umask設定了使用者建立檔案的預設 許可權,它與chmod的效果剛好相反,umask設定的是許可權 補碼 而chmod設定的是檔案許可權碼。一般可在 etc profile etc bash...
Linux命令 許可權管理命令 umask
umask s 顯示使用者建立目錄或檔案時的預設許可權 mkdir shuaige 建立乙個shuaige目錄 ls ld shuaige 檢視shuaige目錄當前的許可權 和上面預設的許可權是一樣的 touch l abcd 建立乙個abcd檔案 ls l abcd 檢視abcd檔案的權錢 注意...
linux中umask命令介紹
umask命令概述 登入系統之後建立乙個檔案或者目錄總是有乙個預設許可權的,這個預設的許可權就是umask來處理的。umask設定了使用者建立檔案和目錄的預設許可權。檢視本機的umask許可權 可選項 p 列印當前umask值 s 顯示當前掩碼 新建檔案和目錄方面的知識 如何計算新建目錄和檔案的預設...