今天來說一下linux中的檔案基本屬性。
linux系統是一種典型的多使用者系統,不同的使用者處於不同的地位,所以各自擁有的許可權也就不同。
為了保護系統的安全性,linux系統對不同的使用者訪問同一檔案(包括目錄檔案)的許可權做了不同的規定。
在linux中我們可以使用 【ll】或者【ls -l 】命令來檢視乙個檔案的屬性以及檔案所需的使用者和組。
範例1:使用【ls -l】命令檢視檔案屬性
上面的範例中bin檔案的第乙個屬性用「d」表示,「d」在linux中代表該檔案是乙個目錄檔案[root@localhost /]# ls -ltotal 64
dr-xr-xr-x 2 root root 4096 dec 14 2021 bin
dr-xr-xr-x 4 root root 4096 apr 19 2021 boot
在linux中第乙個字元代表這個檔案型別,可能是目錄 、檔案 、鏈結檔案等等。
如果【d】,則是目錄如果【-】,則是檔案如果【l】,則表示為鏈結文件(link file)如果【b】,則表示為裝置檔案裡面的可供儲存的介面裝置(可隨機訪問裝置)接下來的字元中,以三個為一組,且均為【rwx】的三個引數的組合。如果【c】,則表示為裝置檔案裡面的串列埠裝置,例如鍵盤、滑鼠(一次性讀取裝置)
其中,【r】代表(read)、【w】代表可寫(write)、【x】代表可執行(execute) 【-】代表沒有許可權
每個檔案的屬性由左邊第一部分的10個字元來確定(如下圖)
從左至右用0-9這些數字來表示
1、第0位確定檔案型別
2、第1-3位確定屬主(該檔案的所有者)擁有該檔案的許可權
3、第4-6位確定屬組(所有者的同組同戶)擁有該檔案的許可權
4、第7-9位確定其他使用者擁有該檔案的許可權然後
一般情況下,有寫許可權的一定會讀許可權,就像有執行許可權的一定會有讀許可權。
對於某個檔案來說,它都有一定特定的所有者,也就是對該檔案具有所有權的使用者[root@localhost mail]# ls -ltotal 128
-rw-rw---- 1 502 mail 0 jun 20 2013 git
-rw-rw---- 1 www mail 0 jun 20 2013 www
drwxr-xr-x 2 root root 4096 feb 15 14:46 cron
drwxr-xr-x 3 mysql mysql 4096 apr 21 2014 mysql
...
以此同時,在linux系統中,使用者是按組分類的,乙個使用者屬於乙個或多個組
檔案所有者以外的使用者又可以分為檔案所有者的同組使用者和其他使用者
因此,linux系統按檔案所有者、檔案所有者同組同戶和其他使用者來規定了不同的檔案訪問許可權
對於root使用者來說,一般情況下,檔案的許可權對其不起作用
chgrp 命令可以用來更改檔案屬組
chgrp [-r]屬組名檔名引數選項
chown命令可以更改檔案屬主,也可以同時更改檔案屬組
chown [-r] 屬主名 檔名進入/root目錄(~)將dev.log的擁有者改為www這個賬號:chown [-r] 屬主名: 屬組名 檔名
將dev.log的擁有者與群組改回為root[root@localhost ~] cd ~[root@localhost ~]# chown www dev.log
[root@localhost ~]# ls -l
-rw-r--r-- 1 www root 68495 jun 25 08:53 dev.log
chmod 命令可以更改檔案9個屬性[root@localhost ~]# chown root:root dev.log[root@localhost ~]# ls -l
-rw-r--r-- 1 dev dev 68495 jun 25 08:53 dev.log
linux檔案屬於有兩種設定方法,一種是數字,一種是符號
linux檔案的基本許可權就有九個,分別是owner/group/others三種身份各有自己的read/write/execute 許可權
先看看剛剛上面提到的資料:檔案的許可權字元為:【-rwxrwxrwx】,這九個許可權是三個三個一組的!其中,我們可以使用數字來代表各個許可權,各許可權的分數對照表如下:
每種身份(owner/group/others)各自的三個許可權(r/w/x)分數是需要累加的,例如當許可權為【-rwxrwx---】分數則是
所以等一下我們設定許可權的變更時,該檔案的許可權數字就是770變更許可權的指令chmod的語法是這樣的:
chmod [-r] xyz 檔案或目錄選擇與引數:
舉例來說,如果要將.bashrc這個檔案所有的許可權都設定啟用,那麼命令如下:
那如果要將許可權變成-rwxr-xr--呢?那麼許可權的分數就成為[4+2+1][4+0+1][4+0+0]=754[root@localhost ~]# ls -al .bashrc-rw-r--r-- 1 root root 395 jul 4 11:45 .bashrc
[root@localhost ~]# chmod 777 .bashrc
[root@localhost ~]# ls -al .bashrc
-rwxrwxrwx 1 root root 237 jun 21 2014 .bashrc
符號型別改變檔案許可權
還有一種改變許可權的方法,我們在上面提到過,九個許可權分別是(1)user (2)group (3)others身份
那麼我們就可以使用u,g,o來代表三種身份的許可權
此外,a則代表 all亦即全部的身份!那麼讀寫的許可權可以寫成r、w、x!也就是可以使用底下的方式來看:
chmod
ugoa
+(加入)-(除去)=(設定)
rwx檔案或目錄
也就是說如果我們需要將檔案許可權設定為 -rwxr-xr--,可以使用chmod u=rwx,g=rx,o=r檔名來設定:
而如果是要將許可權去掉而不改變其他已存在的許可權呢?例如要拿掉全部人的可執行許可權,則:[root@localhost ~]# ls -al .bashrc-rwxr-xr-x 1 root root 395 jul 4 11:45 .bashrc
[root@localhost ~]# chmod a+w .bashrc
[root@localhost ~]# ls -al .bashrc
-rwxrwxrwx 1 root root 395 jul 4 11:45 .bashrc
今天就到這裡,明天繼續學習![root@localhost ~]# chmod a-x .bashrc[root@localhost ~]# ls -al .bashrc
-rw-rw-rw- 1 root root 395 jul 4 11:45 .bashrc
Linux學習計畫
剛畢業時候,接觸過solaris,aix,linux系統,也算業餘在上邊開發了一年多,最近很想把它揀起來。有點懷念過去的味道 最近也很喜歡聽老歌 一,安裝作業系統 本來打算在物理機器上安裝fedora11,但是因為不明原因安裝失敗,只好安裝了ubuntu,感覺不爽,因為原來印象最深刻的是使用redh...
linux 原始碼學習計畫
準備條件 必要的核心 必要的文件 必要的機器 虛擬機器也可 第一周 1.linux和unix相比有哪些特點?2.核心程式設計和使用者空間程式設計相比有哪些不同之處?3.自己編譯一下核心,你編譯成功了麼?如果不成功,有什麼問題?使用你新編譯的核心,能順利啟動麼?有什麼問題?4.linux核心源 樹中你...
linux驅動學習筆記(linux驅動標頭檔案說明)
include 是在linux 2.6.29 include linux下面尋找原始檔。include 是在linux 2.6.29 arch arm include asm下面尋找原始檔。include 是在linux 2.6.29 arch arm mach s3c2410 include ma...