Linux系統結構說明及用途介紹

安全劍客發表於2019-12-04
目錄樹可以分為小的部分,每個部分可以在自己的磁碟或分割槽上。主要部分是根、/usr 、/var 和 /home 檔案系統。每個部分有不同的目的。 每臺機器都有根檔案系統,它包含系統引導和使其他檔案系統得以mount所必要的檔案,根檔案系統應該有單使用者狀態所必須的足夠的內容。還應該包括修復損壞 系統、恢復備份等的工具。

目錄樹可以分為小的部分,每個部分可以在自己的磁碟或分割槽上。主要部分是根、/usr 、/var 和 /home 檔案系統。每個部分有不同的目的。 每臺機器都有根檔案系統,它包含系統引導和使其他檔案系統得以mount所必要的檔案,根檔案系統應該有單使用者狀態所必須的足夠的內容。還應該包括修復損壞 系統、恢復備份等的工具。
/usr 檔案系統包含所有 、庫、man頁和其他一般操作中所需的不改變的檔案。
/usr 不應該有 一般使用中要修改的檔案。這樣允許此檔案系統中的檔案透過網路共享,這樣可以更有效,因為這樣節省了磁碟空間(/usr 很容易是數百兆),且易於管理 (當升級應用時,只有主/usr 需要改變,而無須改變每臺機器) 即使此檔案系統在本地盤上,也可以只讀mount,以減少系統崩潰時檔案系統的損 壞。
/var 檔案系統包含會改變的檔案,比如spool目錄(mail、news、印表機等用的), log檔案、 formatted manual pages和暫存檔案。傳統上/var 的所有東西曾在 /usr 下的某個地方,但這樣/usr 就不可能只讀安裝了。
/home 檔案系統包含使用者家目錄,即系統上的所有實際資料。一個大的/home 可能要分為若干檔案系統,需要在 /home 下加一級名字,如/home/students 、/home/staff 等。

/Etc檔案系統

/etc目錄包含各種系統配置檔案,下面說明其中的一些。其他的你應該知道它們屬於哪個程式, 並閱讀該程式的man頁。許多網路配置檔案也在/etc中。

1、/etc/rc或/etc/rc.d或/etc/rc?.d:啟動、或改變執行級時運 行的 或 的目錄。

2、/etc/passwd:使用者資料庫,其中的域給出了使用者名稱、真實姓名、使用者起始目 錄、加密口令和使用者的其他資訊。

3、/etc/fdprm:軟盤參數列,用以說明不同的軟盤格式。可用setfdprm進 行設定。更多的資訊見setfdprm的幫助頁。

4、/etc/fstab:指定啟動時需要自動安裝的檔案系統列表。也包括用swapon -a啟用的swap區的資訊。

5、/etc/group:類似/etc/passwd ,但說明的不是使用者資訊而是組的資訊。包括組的各種資料。

6、/etc/inittab:init 的配置檔案。

7、/etc/issue:包括使用者在登入提示符前的輸出資訊。通常包括系統的一段短說明 或歡迎資訊。具體內容由系統管理員確定。

8、/etc/magic:“file”的配置檔案。包含不同檔案格式的說 明,“file”基於它猜測檔案型別。

9、/etc/motd:motd是message of the day的縮寫,使用者成功登入後自動輸出。內容由系統管理員確定。
常用於通告資訊,如計劃關機時間的警告等。

10、/etc/mtab:當前安裝的檔案系統列表。由指令碼(scritp)初始化,並由 mount 自動更新。當需要一個當前安裝的檔案系統的列表時使用(例如df命令)。

11、/etc/shadow:在安裝了影子(shadow)口令軟體的系統上的影子口令 檔案。影子口令檔案將/etc/passwd檔案中的加密口令移動到/etc/shadow中,而後者只對超級使用者(root)可讀。這使破譯口令更困 難,以此增加系統的安全性。

12、/etc/login.defs:login命令的配置檔案。

13、/etc/printcap:類似/etc/termcap ,但針對印表機。語法不同。

14、/etc/profile 、/etc/csh.login、/etc/csh.cshrc:登 錄或啟動時bourne或c s執行的檔案。這允許系統管理員為所有使用者建立全域性預設環境。

15、/etc/securetty:確認安全終端,即哪個終端允許超級使用者(root) 登入。一般只列出虛擬控制檯,這樣就不可能(至少很困難)透過調變解調器(modem)或網路闖入系統並得到超級使用者特權。

16、/etc/shells:列出可以使用的shell。chsh命令允許使用者在本檔案 指定範圍內改變登入的shell。提供一
臺機器ftp服務的服務程式ftpd檢查使用者shell是否列在/etc/shells檔案 中,如果不是,將不允許該使用者登入。

17、/etc/termcap:終端效能資料庫。說明不同的終端用什麼“轉義序列”控 制。寫程式時不直接輸出轉義
序列(這樣只能工作於特定品牌的終端),而是從/etc/termcap中查詢要做的工作的 正確序列。這樣,多數的程式可以在多數終端上執行。

/Dev檔案系統

/dev目錄包括所有裝置的裝置檔案。裝置檔案用特定的約定命名,這在裝置列表中說明。裝置檔案在安裝時由系 統產生,以後可以用/dev/makedev描述。/dev/makedev.local 是系統管理員為本地裝置檔案(或連線)寫的描述文稿(即如一些非標準裝置驅動不是標準makedev 的一部分)。下面簡要介紹/dev下 一些常用檔案。

1、/dev/console:系統控制檯,也就是直接和系統連線的監視器。

2、/dev/hd:ide硬碟驅動程式介面。如:/dev/hda指的是第一個硬 盤,had1則是指/dev/hda的第一個分割槽。如系統中有其他的硬碟,則依次為/dev /hdb、/dev/hdc、… …;如有多個分割槽則依次為hda1、hda2 … …

3、/dev/sd:scsi磁碟驅動程式介面。如系統有scsi硬碟,就不會訪問/dev/had, 而會訪問/dev/sda。

4、/dev/fd:軟碟機裝置驅動程式。如:/dev/fd0指 系統的第一個軟盤,也就是通常所說的a盤,/dev/fd1指第二個軟盤,… …而/dev/fd1 h1440則表示訪問驅動器1中的4.5高密盤。

5、/dev/st:scsi磁帶驅動器驅動程式。

6、/dev/tty:提供虛擬控制檯支援。如:/dev/tty1指 的是系統的第一個虛擬控制檯,/dev/tty2則是系統
的第二個虛擬控制檯。

7、/dev/pty:提供遠端登陸偽終端支援。在進行telnet登入時就要用到/dev/pty設 備。

8、/dev/ttys:計算機序列介面,對於dos來說就是“com1”口。

9、/dev/cua:計算機序列介面,與調變解調器一起使用的裝置。

10、/dev/null:“黑洞”,所有寫入該裝置的資訊都將消失。例如:當想要將螢幕 上的輸出資訊隱藏起來
時,只要將輸出資訊輸入到/dev/null中即可。

/Usr檔案系統

/usr是個很重要的目錄,通常這一檔案系統很大,因為所有程式安裝在這裡。/usr裡 的所有檔案一般來自 發行版;本地安裝的程式和其他東西在/usr/local下,因為這樣可以在升級新版系 統或新發行版時無須重新安裝全部程式。/usr目錄下的許多內容是可選的,但這些功能會使使用者使用系統更加有效。/usr可容納許多大型的軟體包和它們的 配置檔案。下面列出一些重要的目錄(一些不太重要的目錄被省略了)。

1、/usr/x11r6:包含x window系統的所有可執行程式、配置檔案和支援檔案。為簡化x的開發和安裝,x的檔案沒有整合到系統中。x window系統是一個功能強大的圖形環境,提供了大量的圖形工具程式。使用者如果對microsoft windows比較熟悉的話,就不會對x window系統感到束手無策了。

2、/usr/x386:類似/usr/x11r6 ,但是是專門給x 11 release 5的。

3、/usr/bin:集中了幾乎所有使用者命令,是系統的軟體庫。另有些命令在/bin或/usr/local/bin中。

4、/usr/sbin:包括了根檔案系統不必要的系統管理命令,例如多數服務程式。

5、/usr/man、/usr/info、/usr/doc:這些目錄包含所有手冊頁、 gnu資訊文件和各種其他文件檔案。每個聯機手冊的“節”都有兩個子目錄。例如:/usr/man/man1中包含聯機手冊第一節的原始碼(沒有格式化的原 始檔案),/usr/man/cat1包含第一節已格式化的內容。聯機手冊分為以下九節:內部命令、系統呼叫、庫函式、裝置、檔案格式、遊戲、宏軟體包、 系統管理和核心程式。

6、/usr/include:包含了c語言的標頭檔案,這些檔案多以.h結尾,用來描述c 語言程式中用到的資料結構、
子過程和常量。為了保持一致性,這實際上應該放在/usr/lib下,但習慣上一直沿用了這 個名字。

7、/usr/lib:包含了程式或子系統的不變的資料檔案,包括一些site - wide配置檔案。名字lib來源於庫(library); 程式設計的原始庫也存在/usr/lib 裡。當編譯程式時,程式便會和其中的庫進行連線。也有許多程式把配置檔案存入其中。

8、/usr/local:本地安裝的軟體和其他檔案放在這裡。這與/usr很相似。使用者 可能會在這發現一些比較大 的軟體包,如tex、emacs等。

/Var檔案系統

/var包含系統一般執行時要改變的資料。通常這些資料所在的目錄的大小是要經常變化或擴充 的。原來/var目錄中有些內容是在/usr中的,但為了保持/usr目錄的相對穩定,就把那些需要經常改變的目錄放到/var中了。每個系統是特定的, 即不透過網路與其他計算機共享。下面列出一些重要的目錄(一些不太重要的目錄省略了)。

1、/var/catman:包括了格式化過的幫助(man)頁。幫助頁的原始檔一般存在 /usr/man/catman中;有些man頁可能有預格式化的版本,存在/usr/man/cat中。而其他的man頁在第一次看時都需要格式化,格 式化完的版本存在/var/man中,這樣其他人再看相同的頁時就無須等待格式化了。(/var/catman經常被 清除,就像清除臨時目錄一樣。)

2、/var/lib:存放系統正常執行時要改變的檔案。

3、/var/local:存放/usr/local中 安裝的程式的可變資料(即系統管理員安裝的程式)。注意,如果必要,
即使本地安裝的程式也會使用其他/var目錄,例如/var/lock 。

4、/var/lock:鎖定檔案。許多程式遵循在/var/lock中 產生一個鎖定檔案的約定,以用來支援他們正在
使用某個特定的裝置或檔案。其他程式注意到這個鎖定檔案時,就不會再使用這個裝置或檔案。

5、/var/log:各種程式的日誌(log)檔案,尤其是login (/var/log/wtmplog紀 錄所有到系統的登入和登出) 和syslog (/var/log/messages 紀錄儲存所有核心和系統程式資訊)。/var/log 裡的檔案經常不確定地增長,應該定期清除。

6、/var/run:儲存在下一次系統引導前有效的關於系統的資訊檔案。例如,/var/run/utmp包 含當前登入的使用者的資訊。

7、/var/spool:放置“假離線(spool)”程式的目錄,如mail、 news、列印佇列和其他佇列工作的目錄。每
個不同的spool在/var/spool下有自己的子目錄,例如,使用者的郵箱就存放在/var/spool/mail 中。

8、/var/tmp:比/tmp允許更大的或需要存在較長時間的臨時檔案。注意系統管理 員可能不允許/var/tmp有很舊的檔案。

/Proc檔案系統

/proc檔案系統是一個偽的檔案系統,就是說它是一個實際上不存在的目錄,因而這是一個非 常特殊的目錄。它並不存在於某個磁碟上,而是由核心在記憶體中產生。這個目錄用於提供關於系統的資訊。下面說明一些最重要的檔案和目錄(/proc檔案系統 在proc man頁中有更詳細的說明)。

1、/proc/x:關於程式x的資訊目錄,這x是這一程式的標識號。每個程式在 /proc下有一個名為自己程式號的目錄。

2、/proc/cpuinfo:存放處理器(cpu)的資訊,如cpu的型別、製造商、 型號和效能等。

3、/proc/devices:當前執行的核心配置的裝置驅動的列表。

4、/proc/dma:顯示當前使用的dma通道。

5、/proc/filesystems:核心配置的檔案系統資訊。

6、/proc/interrupts:顯示被佔用的中斷資訊和佔用者的資訊,以及被佔用 的數量。

7、/proc/ioports:當前使用的i/o埠。

8、/proc/kcore:系統實體記憶體映像。與實體記憶體大小完全一樣,然而實際上沒有 佔用這麼多記憶體;它僅
僅是在程式訪問它時才被建立。(注意:除非你把它複製到什麼地方,否則/proc下沒有任何東西佔用任何磁碟空間。)

9、/proc/kmsg:核心輸出的訊息。也會被送到syslog。

10、/proc/ksyms:核心符號表。

11、/proc/loadavg:系統“平均負載”;3個沒有意義的指示器指出系統當前 的工作量。

12、/proc/meminfo:各種儲存器使用資訊,包括實體記憶體和交換分割槽 (swap)。

13、/proc/modules:存放當前載入了哪些核心模組資訊。

14、/proc/net:網路協議狀態資訊。

15、/proc/self:存放到檢視/proc的 程式的程式目錄的符號連線。當2個程式檢視/proc時,這將會是不同
的連線。這主要便於程式得到它自己的程式目錄。

16、/proc/stat:系統的不同狀態,例如,系統啟動後頁面發生錯誤的次數。

17、/proc/uptime:系統啟動的時間長度。

18、/proc/version:核心版本。

/usr/local下一般是你安裝軟體的目錄,這個目錄就相當於在windows下的programefiles這個目錄
/opt這個目錄是一些大型軟體的安裝目錄,或者是一些服務程式的安裝目錄

舉個例子:剛才裝的測試版firefox,就可以裝到/opt/firefox_beta目錄下,/opt/firefox_beta目錄下面就包含了運 行firefox所需要的所有檔案、庫、資料等等。要刪除firefox的時候,你只需刪除/opt/firefox_beta目錄即可,非常簡單。

原文地址:

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31559985/viewspace-2666963/,如需轉載,請註明出處,否則將追究法律責任。

相關文章