能夠看到,用ls -l命令查看某一個目錄會獲得一個7個字段的列表。linux
第1行:總計(total)shell
Total後面的數字是指當前目錄下全部文件所佔用的空間總和。可使用ls –lh查看,也可以使用ls –alh查看。編程
第1字段: 文件屬性字段windows
-rw-r--r--. 1 root root 100 12月 19 19:28 daemon.logspa
文件屬性字段總共有10個字母組成;第一個字符表明文件的類型。3d
字母「-」表示該文件是一個普通文件blog
字母「d」表示該文件是一個目錄,字母"d",是dirtectory(目錄)的縮寫it
注意:目錄或者是特殊文件,這個特殊文件存放其餘文件或目錄的相關信息class
字母「l」表示該文件是一個連接文件。字母"l"是link(連接)的縮寫,相似於windows下的快捷方式test
字母「b」的表示塊設備文件(block),通常置於/dev目錄下,設備文件是普通文件和程序訪問硬件設備的入口,是很特殊的文件。沒有文件大小,只有一個主設備號和一個輔設備號。一次傳輸數據爲一整塊的被稱爲塊設備,如硬盤、光盤等。最小數據傳輸單位爲一個數據塊(一般一個數據塊的大小爲512字節)
字母爲「c」表示該文件是一個字符設備文件(character),通常置於/dev目錄下,一次傳輸一個字節的設備被稱爲字符設備,如鍵盤、字符終端等,傳輸數據的最小單位爲一個字節。
字母爲「p」表示該文件爲命令管道文件。與shell編程有關的文件。
字母「s」表示該文件爲sock文件。與shell編程有關的文件。
第1字符的後面9個字母表示該文件或目錄的權限位。
r表是讀 (Read) 、w表示寫 (Write) 、x表示執行 (eXecute)
其中前三個表示文件擁有者的權限,中間三個表示文件所屬組擁有的權限,最後三個表示其餘用戶擁有的權限。
第2字段:文件硬連接數
-rw-r--r--. 1 root root 100 12月 19 19:28 daemon.log
若是一個文件不是目錄,此時這一字段表示這個文件所具備的硬連接數,
第2字段的值爲1,說明這個文件只有daemon.log這一個文件名。即只有一個指向該連接的硬連接。。
若是使用ln,作一個指向該文件的硬連接再查看該文件,該文件的第2字段就會變成2
此時daemon.log 和daemon稱爲互爲硬連接。他們指向同一個文件,不管是修改哪個文件,另外一個裏也作相應的變化,由於實際上他們指向同一個文件(即同一文件的不一樣文件名)
互爲硬連接的文件具備相同的文件節點。
能夠看出,這兩個文件具備相同的文件節點號:162302
能夠設置符號連接(軟連接),格式以下
ln –s 源文件 目標連接文件
注意:軟連接時文件節點號不同:
若是知道一個文件有多個文件名(連接文件)如何查找他的其餘文件名分佈在什麼地方呢?
能夠先用ls -i 得到它的節點號,而後用find查找,如 /home/zzw/Desktop/網設大做業/第一次 要查找與它互爲硬連接的文件
獲得它的節點號爲 207131084
再用find查找:
這樣就獲得了同一個文件的不一樣文件名的位置
(此處文件只有一個文件名)
第2字段: 連接佔用的節點
-rw-r--r--. 1 root root 100 12月 19 19:28 log ->daemon.log
該字段文件佔用一個節點,屬於軟連接(符號連接)
若是是一個目錄,則第2字段表示該目錄所含子目錄的個數。
新建一個空目錄,這個目錄的第二字段就是2,表示該目錄下有兩個子目錄。爲何新建的目錄下面會有兩個子目錄呢?
由於每個目錄都有一個指向它自己的子目錄"。" 和指向它上級目錄的子目錄"。。",這兩個默認子目錄是隱藏的。ls -a能夠看到
每次在目錄下新建一個子目錄,該目錄第2字段的值就增1,可是新建一個普通文件該字段值不增長。
第3字段:文件(目錄)擁有者
-rw-r--r--. 1 root root 100 12月 19 19:28 log ->daemon.log
該字段表示此文件是屬於哪一個用戶。linux類系統都是多用戶系統,每一個文件都有它的擁有者。只有文件的擁有者才具備改動文件屬性的權利。
固然, root用戶具備改動任何文件屬性的權利。對於一個目錄來講,只有擁有該目錄的用戶,或者具備寫權限的用戶纔有在目錄下建立文件的權利
若是某一個用戶由於某種緣由,被刪除,而該用戶的文件還存在,那麼用ls -l 查看該文件將顯示一個表明用戶存在前ID號的數字。
先建立一個用戶test,將其加入wang用戶組,並用su切換,使用ls –l查看文件擁有者,隨即刪除用戶test,用root進入test家目錄,查看剛剛建立的文件testing。
能夠看到,第三字段成了一個數字,這個數字是原test用戶的ID號。由於文件系統對每一個文件記錄文件全部者的ID,而非用戶名。
第4字段:文件(目錄)擁有者所在的組
-rw-r--r--. 1 root root 100 12月 19 19:28 log ->daemon.log
一個用戶能夠加入不少個組,可是其中有一個是主組,就是顯示在第4字段的名稱。
能夠在useradd的時候用-g指定該用戶所在的主組,用-g指定其餘組
格式以下:useradd –g 組名 用戶名
第5字段: 文件所佔用的空間(以字節爲單位)
-rw-r--r--. 1 root root 100 12月 19 19:28 log ->daemon.log
第5字段表示文件大小,若是是一個文件夾(目錄),則表示該文件夾的大小。請注意是文件夾自己的大小,而不是文件夾以及它下面的文件的總大小。
不少人不能理解文件夾是一個特殊的文件的含義,這樣的話理解文件夾大小的含義就比較困難了。
第6字段:文件(目錄)最近訪問(修改)時間
-rw-r--r--. 1 root root 100 12月 19 19:28 log ->daemon.log
文件建立的時間能夠經過touch命令來修改。如:
[root@localhost ~]# touch daemon.log
能夠把daemon.log的建立時間修改成當前時間,另外,一個文件還有最後訪問時間,最後修改時間等屬性。
這些屬性能夠用ls 的其它參數顯示出來。
第7字段:文件名
lrwxrwxrwx 1 root root 4 08-03 08:27 log->daemon.log
若是是一個符號連接,那麼會有一個 「->" 箭頭符號,後面根一個它指向的文件名
好比: