linux chmod命令使用
chmod:更改文件9個屬性
Linux文件屬性有兩種設置方法,一種是數字,一種是符號。
Linux文件的基本權限就有九個,分別是owner/group/others三種身份各有自己的read/write/execute權限。
先復習一下剛剛上面提到的數據:文件的權限字符為:『-rwxrwxrwx』, 這九個權限是三個三個一組的!其中,我們可以使用數字來代表各個權限,各權限的分數對照表如下:
- r:4
- w:2
- x:1
每種身份(owner/group/others)各自的三個權限(r/w/x)分數是需要累加的,例如當權限為: [-rwxrwx---] 分數則是:
- owner = rwx = 4+2+1 = 7
- group = rwx = 4+2+1 = 7
- others= --- = 0+0+0 = 0
所以等一下我們設定權限的變更時,該文件的權限數字就是770啦!變更權限的指令chmod的語法是這樣的:
chmod [-R] xyz 文件或目錄選項與參數:
- xyz : 就是剛剛提到的數字類型的權限屬性,為 rwx 屬性數值的相加。
- -R : 進行遞歸(recursive)的持續變更,亦即連同次目錄下的所有文件都會變更
舉例來說,如果要將.bashrc這個文件所有的權限都設定啟用,那么命令如下:
[root@www ~]# ls -al .bashrc -rw-r--r-- 1 root root 395 Jul 4 11:45 .bashrc [root@www ~]# chmod 777 .bashrc [root@www ~]# ls -al .bashrc -rwxrwxrwx 1 root root 395 Jul 4 11:45 .bashrc那如果要將權限變成?-rwxr-xr--?呢?那么權限的分數就成為 [4+2+1][4+0+1][4+0+0]=754。
符號類型改變文件權限
還有一個改變權限的方法呦!從之前的介紹中我們可以發現,基本上就九個權限分別是(1)user (2)group (3)others三種身份啦! 那么我們就可以藉由u, g, o來代表三種身份的權限!
此外, a 則代表 all 亦即全部的身份!那么讀寫的權限就可以寫成r, w, x!也就是可以使用底下的方式來看:
?
| chmod | u g o a | +(加入) -(除去) =(設定) | r w x | 文件或目錄 |
如果我們需要將文件權限設置為?-rwxr-xr--?,可以使用?chmod u=rwx,g=rx,o=r 文件名?來設定:
# touch test1 // 創建 test1 文件 # ls -al test1 // 查看 test1 默認權限 -rw-r--r-- 1 root root 0 Nov 15 10:32 test1 # chmod u=rwx,g=rx,o=r test1 // 修改 test1 權限 # ls -al test1 -rwxr-xr-- 1 root root 0 Nov 15 10:32 test1而如果是要將權限去掉而不改變其他已存在的權限呢?例如要拿掉全部人的可執行權限,則:
# chmod a-x test1 # ls -al test1 -rw-r--r-- 1 root root 0 Nov 15 10:32 test1給文件添加執行權限(所有人的權限都會添加上)
chmod +x hello.sh
-rwxr-xr-x. 1 root root 30 Jan 16 03:10 hello.sh
給文件添加執行權限(只給user添加)
chmod u+x hello.sh?
----------------------------------
chmod a=rwx file
和
chmod 777 file效果相同
chmod ug=rwx,o=x file和
chmod 771 file效果相同
?轉載于:https://www.cnblogs.com/lmg-jie/p/8297299.html
總結
以上是生活随笔為你收集整理的linux chmod命令使用的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 都是套路:高并发系统的降级特技
- 下一篇: UWP 检测网络状态