一、umask命令簡介及作用
umask命令用於設置文件和目錄的默認許可權,是控制默認許可權的重要命令之一。默認許可權是指當用戶新建一個文件或目錄時,系統默認賦予該文件或目錄的許可權。
umask命令所設置的數值,實際上就是目標文件或目錄的「屏蔽位」,該屏蔽位中的每一位與文件許可權位中的每一個相對應,且在相應位置上相同,則在對應位置上被屏蔽。因此,umask值的大小決定了文件、目錄的默認許可權值。
二、umask命令的語法及常見參數
umask [mode]
umask命令後面可以接一個0~777的八進位參數mode,其中指定的位數和相應位置0,表示該位許可權按照默認值來設置,且所有許可權位最終都是被屏蔽的。如輸入umask 022,就意味著默認文件許可權為644(666-022),默認目錄許可權為755(777-022)。
umask命令經常搭配其他命令一起使用,如:
$ umask 022 #設置默認許可權為644 $ touch new_file #新建文件new_file,默認許可權為644 $ mkdir new_dir #新建目錄new_dir,默認許可權為755
三、常見問題及解決方法
1. 如何永久改變umask值?
通過umask命令設置的umask值只在當前shell會話中有效,重新打開一個shell會話後,umask值仍將恢復原來的狀態。若想永久改變umask值,可在環境變數文件(如~/.bashrc)中添加以下語句:
umask 022
將umask值設為022,則每次打開終端默認新建文件的許可權為644。
2. 如何查看umask值?
要查看當前umask值,可以使用umask命令不帶參數來查詢:
$ umask 0022
該輸出表示當前umask值為022。
3. umask能否覆蓋系統默認許可權?
umask設置的是默認許可權,只有在文件和目錄新建時才會生效,無法對已經創建的文件和目錄進行許可權變更。如果需要改變已創建文件和目錄許可權,需要使用chmod命令進行更改。
四、總結
umask命令作為控制默認許可權的重要命令,能夠方便地設置文件和目錄的默認許可權值。在linux系統中,文件和目錄的許可權是安全性和控制性方面重要的一環,因此深入理解umask命令十分必要。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/186391.html