比起Windows,怎樣解讀Linux的檔案系統與目錄結構?

ADVERTISEMENT

Linux 和Windows的檔案系統有些不同,在學習使用 Linux 之前,若能夠瞭解這些不同,會有助於後續學習。

本文先對Windows和 Linux 上面檔案系統原理、組織概念進行區分,並給出例子、列舉兩者的優缺點以具體說明,最後較為詳細地介紹了 Linux 系統的目錄結構。

Windows 和 Linux 檔案系統下面將介紹啟動Windows和 Linux 後,在檔案系統的角度上,它們分別是怎樣看待自己世界的。

訪問原理在Windows系統中, 一切東西都是存放在硬碟上的。啟動系統後,先確定硬碟,再確定硬碟上的分區以及每個分區所對應檔案系統,最後是存放在某個分區特定的檔案系統中的檔案。 也就是說,Windows是通過 “某個硬碟-硬碟上的某個分區-分區上的特定檔案系統-特定檔案系統中的檔案” 這樣的順序來訪問到一個檔案的。

但是與Windows不同, Linux 系統中的一切都是存放在唯一的 虛擬檔案系統中的,這個 虛擬檔案系統是樹狀的結構以一個根目錄開始。啟動系統後,先有這個 虛擬檔案系統,再識別出各個硬碟, 再把某個硬碟的某個分區掛載到這個 虛擬檔案系統的某個子樹上(即分區用某個子目錄來表示),再確定分區對應的子目錄檔案系統,最後的檔案就存放在這個特定的檔案系統中。 也就是說, Linux 系統是通過 “虛擬檔案系統-硬碟-硬碟上的分區-分區上的特定檔案系統-特定檔案系統中的檔案” 這樣的順序來訪問一個檔案的。

可能對習慣了使用Windows的使用者來說, Linux 的方式有些不適應,它的 虛擬檔案系統,實質就是一顆目錄樹,最開始的目錄叫做根目錄,根目錄中又有每一級子目錄,或者檔案,子目錄又有子子目錄和檔案,其中每個子目錄都特定的功能這個功能(這些是約定俗成了的,在後面 常用的重要目錄 (See section 1.2.1) 中會詳細說明)。也許有人會問,沒有這個虛擬檔案系統就無法使用硬碟,可是最開始沒有硬碟,那麼這個 虛擬檔案系統以及相應的組織結構是怎麼存放起來的呢?這個問題,就像先有雞還是先有蛋這個問題一樣看似簡單實則……但是,在 Linux 中,很輕易地跳出了這個思維迴圈,問題的答案並沒在 虛擬檔案系統 和 硬碟 這兩者之間徘徊,而是第三者—— 記憶體 ,Linux系統啟動起來之後,整個 虛擬檔案系統的組織結構,都是隨著每次核心系統的啟動自動在記憶體中建立好了的,根本就不需要硬碟。

另外還要注意,就是在我們使用者的角度上,無論在Windows還是 Linux 上面,都是使用路徑來訪問一個檔案的。表示檔案的路徑由“檔案所在的目錄+各級目錄的分隔符+檔案” 三個部分組成,這個策略在兩者之間是一樣的,所不同的是,Windows下面目錄分隔符是\/,也許這也是兩者之間為了表示其各自立場不同的一個原因吧?^_^在Windows系統中,我們可以把檔案大體分為兩種:系統檔案和使用者檔案 。一般來說系統檔案(例如Windows作業系統本身,一些系統程式,程式執行所需的庫檔案,以及一些系統配置檔案等)存放的預設位置在C盤,當然也可以在安裝時候指定在其他盤;其它使用者檔案,包含使用者後來安裝的程式以及一些資料檔案等,使用者可以把它們隨意存放在任意的分區。在 Linux 系統中,主要有兩個概念: 虛擬檔案系統中的檔案和 Linux作業系統核心本身。邏輯上可以認為前者屬於上層,後者在下層,前者基於後者,後者依賴前者而存在。

Linux 把除了它本身(Linux作業系統核心)以外的一切事物都看作是在 虛擬檔案系統中的檔案了。無論是鍵盤,滑鼠,資料,程式,CPU,記憶體,網卡……無論是硬體、軟體、資料還是記憶體中的東西,我們都可以在 虛擬檔案系統中的相應子目錄對他們進行訪問和操作,操作統一。而實現這些管理的幕後就是Linux作業系統核心本身:啟動 Linux 系統的時候,首先電腦把Linux作業系統核心載入到記憶體中,核心本身提供了檔案管理,裝置管理,記憶體管理,CPU程式排程管理,網路管理等功能,等核心執行起來之後,就在記憶體中建立起相應的 虛擬檔案系統,最後就是核心利用它提供的那些功能,通過管理檔案的方式,來管理 虛擬檔案系統中的硬體軟體等各種資源了。

Linux 把提供作業系統本身功能(管理計算機軟硬體資源)的那些部分劃給了Linux作業系統核心,使得Linux作業系統核心成為一個獨立的部分,有它自己獨立的開原始碼;而其它的一切(軟體應用,硬體驅動,資料)都根據其特性有自己的開原始碼、或者自由地組織並且存放在那個 虛擬檔案系統中由Linux作業系統核心來管理。這樣,將系統本身和系統所管理的資源分開,並開放原始碼,有助於對系統或者系統所管理的資源進行靈活的定製和擴充套件,還能按需快速建立起隻適合自己使用的作業系統,也利於作業系統本身的發展。實際,,RedHat等各種不同的 Linux 作業系統發行版,簡單來說就是不同廠商對其檔案系統和核心進行了不同的配置而產生的“大眾化” 的作業系統。相比之下,Windows就顯得非常地零亂複雜,將系統、軟體、硬體、資料都混在了一起,其不同版本只能由Microsoft一家公司發行。舉例說明下面用直觀的例子,來說明兩者的不同,以加深理解。假設我們的機器上面有一個硬碟,硬碟分為三個區。

在Windows系統中, 我們啟動系統之後就會看到E, 碟符,它們分別對應硬碟上的三個分區,增加硬碟,或者分區,會導致碟符的增加(注意由於歷史原因,ABC開始按字母遞增),這裡的每個分區都各自可以被格式化為不同的檔案系統(這裡的檔案系統,包括例如NTFS格式,FAT32格式等),檔案系統的基本功能就是為了存放檔案的,不同檔案系統區別一般在於管理其中存放的檔案的功能的強弱,所以分區被格式化成指定格式的檔案系統之後,就可以存放任何檔案和目錄了,我們看到的C但是,與Windows中把硬碟分區看成碟符不同, Linux 中最開始根本就沒有硬碟的概念,就只有一個純粹的 虛擬檔案系統。如果想要使用哪個硬碟的某個分區,就把那個分區“掛載” 到某個子目錄之下,這樣硬碟中的分區,檔案系統,目錄等內容就呈現到了那個子目錄裡面。也就是說,在 Linux 中,我們使用硬碟中的資料,實際是先把硬碟的某個分區“掛載” 到某個子目錄下,然後通過那個子目錄來訪問的。這個例子中, 通常硬碟會對應 虛擬檔案系統中的/dev/sda(如有多個硬碟,則為/dev/sda/dev/sdb, ……, 按字母遞增), 其三個分區對應/dev/sda1/dev/sda3(多個分區按數字遞增,不同硬碟的分區,對應為/dev/sdb1/dev/sdb2等等), 預設硬碟各個分區會被掛載到 虛擬檔案系統系統中類似/mnt/sda1/,的目錄(在 Linux 又叫掛載點)中,在/etc/fstab檔案中,我們可以找到分區檔案和掛載點的對應關係描述。這樣,硬碟相應的分區就做為整個 虛擬檔案系統根目錄下的一顆子樹,反映到了子目錄(掛載點)上,子目錄中的內容就對應分區中的資料。假設訪問上述硬碟第三個分區dir1目錄中的檔案test.file

Windows系統中

指定或不指定安裝路徑類似,程式的安裝目錄會在C:\Program Files\Firefox類似的目錄中,或指定的安裝路徑中; 可執行檔案一般在程式的安裝路徑;依賴的內部庫、第三方庫、和系統庫可能在安裝路徑中,也可能在C:\Windows\下的某些檔案中(比如登入檔資料庫檔案、使用者目錄等),這就不一定了。而且不同的系統版本,應用程式版本下,這些目錄的具體名稱和路徑可能會有所不同。解除安裝的時候由於不確定哪些地方安裝了什麼內容,很容易造成檔案刪除補全,遺留系統垃圾等現象,造成系統越來越癱腫。Linux 系統中

如果不指定安裝路徑,所有程式的可執行檔案在/usr/bin中, 全局配置檔案在/etc/firefox類似的目錄, 使用者配置檔案一般在使用者主目錄的.firefox的路徑下(使用者主目錄路徑名稱統一格式為/home/) ,依賴的內部庫和第三方庫在/usr/lib, 系統庫在/lib下, 資料檔案一般就在使用者主目錄下。 如果指定安裝目錄,那麼所有內部庫和可執行程式,全局配置檔案,會在下的binetc子目錄下,其它檔案一般和預設情況相同。解除安裝程式之時,隻需在對應目錄中,將可執行檔案、內部庫、配置檔案、資料檔案刪除即可,基本沒有不確定是否遺留垃圾檔案的問題。這些都是大多數應用程式安裝的和訪問的預設策略,就像是不成文的業界標準,不排除有個別程式不安裝這種策略部署應用,但是 Linux 使用者帶來 “麻煩“ 的應用,早晚也會被淘汰,不可能會流行在 Linux 系統中,這樣,自然的,好的應用都儲存在 Linux 系統中並逐漸流行起來,還不會破壞系統結構。可見, Linux 檔案的存放和組織明顯方式更高效,層次更分明。

優缺點基於上述內容,Windows和 Linux 檔案系統的各有優缺點分別如下。

Windows系統優點

優點主要是使用者存放東西的位置比較自由,系統結構簡單便於新使用者上手。

ADVERTISEMENT

Windows系統缺點

缺點較多主要有:

目錄組織缺乏標準

由於對“系統檔案”和“使用者檔案”存放位置缺乏細緻的規定,資料組織的方式顯得比較淩亂,並且兩種檔案之間很容易相互幹擾(例如資料檔案可能存放在系統區域給系統帶來垃圾檔案等)。

使用者的使用經驗對系統的使用效率影響很大

一般來說,我們使用Windows時候合理使用分區會提升的系統效率。例如根據需要設定合理的系統分區(假設為CCCCX:\Program Files表示碟符而不要自己定義一些奇怪名字的目錄,這樣便於軟體的維護等等。共享不便

Windows上有經驗的使用者們會將自己的目錄結構組織好,但是每個使用者組織自己內容的方式是不一樣的,所以他的機器上哪裡存放了什麼內容,別人很難知道,為共享帶來了麻煩。

Linux 系統缺點

最開始虛擬檔案系統中的每個子目錄的功能是事先規定好了的,我們需要事先知道那些目錄存放哪些檔案,然後在相應的位置中建立自己的內容,這也是 Linux 系統入門門檻高的一個原因。當然,最開始的新手,也完全可以無視這一點,可以像Windows那樣隨意地建立目錄和檔案(儘管不推薦這麼做)。

實際上最開始的目錄也不多,主要就那麼幾個,花不了多長時間就會明白它們的作用的,而明白這些作用之後帶來的好處,遠不止付出那麼多(本文後面 常用的重要目錄 (See section 1.2.1) 會著重對此進行介紹)。

Linux 系統優點

這裡隻說幾個優點:

目錄結構反映系統執行機理

當我們瞭解了這些目錄的功能之後,我們對整個 Linux 作業系統的執行機理也會有一個大致的瞭解。

結構清晰避免邏輯混亂

這樣的目錄結構,有助於我們以一種高效的方式組織自己的資料,分類清晰並且不會對系統執行有任何影響,規定了最開始每個目錄的功能,並沒有限制我們的自由,因為我們知道我們可以在哪裡建立自己的子目錄並且在子目錄中任意建立自己的檔案。

ADVERTISEMENT

組織規範便於共享

由於目錄具有統一的組織結構,所以 Linux 上面的使用者在共享資料的時候,能夠很容易地猜測出他所需要的資料大致存放在什麼位置,同時也不會影響到私有資料的保密性,畢竟具體來說,怎麼存放自己的私有資料,那是使用者自己決定的。

Linux 上面的虛擬檔案系統目錄組織實質上,我們啟動系統所看到的 “根目錄” ,邏輯上是 Linux 虛擬檔案系統的根目錄中的一個子目錄,我們看不到除了這個 “根目錄” 以外的其他的目錄,那些目錄和作業系統的具體實現相關是被作業系統核心隱藏起來了的,所以這裡就介紹我們所能看到的檔案系統中的 “根目錄” 的各個子目錄中的作用吧。

在 Linux 檔案系統中的每一個子目錄都有特定的目的和用途。一般都是根據FHS標準定義一個正式的檔案系統結構的,這個標準規定了哪些目錄應該哪些作用。這裡我們先介紹一些日常經常用到的目錄,然後給出FHS相關的內容。常用的重要目錄這裡,根據本人的使用經驗,給出比較常見重要的一些目錄,最開始我們對它們有所瞭解就可以了。隨著對 Linux 使用的經驗的加深,我們會瞭解越來越多的目錄。對目錄的功能知道得越多,我們對 Linux 系統的工p作原理就理解的越深刻,理解作業系統的工作原理,更助於我們更為規範地使用和理解系統中每個目錄存在的意義,直至最後幾乎知道系統中的每個檔案……

包含了幾乎所的檔案目錄。相當於中央系統。進入的最簡單方法是:cd /。

/boot 引導程式,核心等存放的目錄

這個目錄,包括了在引導過程中所必需的檔案,引導程式的相關檔案(例如 grub , lilo 以及相應的配置檔案)以及 Linux 作業系統核心相關檔案(例如 vmlinuz 等)一般都存放在這裡。在最開始的啟動階段,通過引導程式將核心載入到記憶體,完成核心的啟動(這個時候, 虛擬檔案系統還不存在,載入的核心雖然是從硬碟讀取的,但是沒經過 Linux 的 虛擬檔案系統,這是比較底層的東西來實現的)。然後核心自己建立好 虛擬檔案系統,並且從 虛擬檔案系統的其他子目錄中(例如 /sbin 和 /etc )載入需要在開機啟動的其他程式或者服務或者特定的動作(部分可以由使用者自己在相應的目錄中修改相應的檔案來配製)。如果我們的機器中包含多個作業系統,那麼可以通過修改這個目錄中的某個配置檔案(例如 grub.conf )來調整啟動的預設作業系統,系統啟動的擇選單,以及啟動延遲等參數。

/sbin 超級使用者可以使用的命令的存放目錄

存放大多涉及系統管理的命令(例如引導系統的 init 程式),是超級許可權使用者 root 的可執行命令存放地,普通使用者無許可權執行這個目錄下的命令(但是有時普通使用者也可能會用到)。這個目錄和 /usr/sbin , /usr/X11R6/sbin或/usr/local/sbin 等目錄是相似的,我們要記住,凡是目錄 sbin 中包含的都是 root 許可權才能執行的,這樣就行了。後面會具體區分。

系統所需要的那些命令位於此目錄,比如ls、cp、mkdir等命令;類似的目錄還/lib此目錄下包含系統引導和在根使用者執行命令時候所必需用到的共享庫。做個不太好但是比較形象的比喻,點類似於Windows上面的system32目錄。按理說,這裡存放的檔案應該是/bin目錄下程式所需要的庫檔案的存放地,也不排除一些例外的情況。類似的目錄還在 Linux 中裝置都是以檔案形式出現,這裡的裝置可以是硬碟,鍵盤,滑鼠,網卡,終端,等裝置,通過訪問這些檔案可以訪問到相應的裝置。裝置檔案可以使用mknod命令來建立,具體參見相應的命令;而為了將對這些裝置檔案的訪問轉化為對裝置的訪問,需要向相應的裝置提供裝置驅動模組(一般將裝置驅動編譯之後,生成的結果是一個*.koinsmod等命令載入相應的裝置驅動之後,我們就可以通過裝置檔案來訪問裝置了。一般來說,想要 Linux 系統支援某個裝置,隻需要三個東西:相應的硬體裝置,支援硬體的驅動模組,以及相應的裝置檔案。/home$HOME在 Linux 機器上,使用者主目錄通常直接或間接地置在此目錄下。其結構通常由本地機的管理員來決定。通常而言,系統的每個使用者都有自己的家目錄,目錄以使用者名作為名字存放在/home下面(例如quietheart使用者,其家目錄的名字為/home/quietheart)。該目錄中儲存了絕大多數的使用者檔案(使用者自己的配置檔案,定製檔案,檔案,資料等),root使用者除外(參見後面的/root目錄)。由於這個目錄包含了使用者實際的資料,通常系統管理員為這個目錄單獨掛載一個獨立的磁碟分區,這樣這個目錄的檔案系統格式就可能和其他目錄不一樣了(儘管表面上看,這個目錄還是屬於根目錄的一棵子樹上),將系統檔案和資料檔案分開存放,有利於維護。/root$HOME系統管理員(就是root使用者或超級使用者)的主目錄比較特殊,不存放在/home/root/etc系統和程式一般都可以通過修改相應的配置檔案,來進行配置。例如,要配置系統開機的時候啟動那些程式,配置某個程式啟動的時候顯示什麼樣的風格等等。通常這些配置檔案都集中存放在/etc目錄中,所以想要配置什麼東西的話,可以在/etc下面尋找我們可能需要修改的檔案。一些大型套件,如X11,在/etc下它們自己的子目錄。系統配置檔案可以放在這裡或在/usr/etc。 不過所有程式總是在/etc目錄下查詢所需的配置檔案,你也可以將這些檔案連結到目錄/usr/etc。另外,還一個需要注意的常見現象就是,當某個程式在某個使用者下執行的時候,可能會在該使用者的家目錄中生成一個配置檔案(一般這個檔案最開始就是/etc下相應配置檔案的拷貝,存放相應於“當前使用者”的配置),這樣當前使用者可以通過配置這個家目錄的配置檔案,來改變程式的行為,並且這個行為只是該使用者特有的。原因就是:一般來說一個程式啟動,如果需要讀取一些配置檔案的話,它會首先讀取當前使用者家目錄的配置檔案,如果存在就使用;如果不存在它就到/etc下讀取全局的配置檔案進而啟動程式。就是這個配置檔案不自動生成,我們手動在自己的家目錄中建立一個檔案的話,也有許多程式會首先讀取到這個家目錄的檔案並且以它的配置作為啟動的選項(例如我們可以在家目錄中建立vim程式的配置檔案.vimrc,來配置自己的vim程式)。/usr 這個目錄中包含了命令庫檔案和在通常操作中不會修改的檔案

這個目錄對於系統來說也是一個非常重要的目錄,其地位類似Windows上面的 Program Files 目錄(請原諒我可能這樣做比較不太恰當^_^)。安裝程式的時候,預設就是安裝在此檔案內部某個子資料夾內。輸入命令後系統預設執行 /usr/bin 下的程式(當然,前提是這個目錄的路徑已經被新增到了系統的環境變數中)。此目錄通常也會掛載一個獨立的磁碟分區,它應儲存共享隻讀類檔案,這樣它可以被執行 Linux 的不同主機掛載。

/usr/lib 目標庫檔案,包括動態連線庫加上一些通常不是直接呼叫的可執行檔案的存放位置

這個目錄功能類似 /lib 目錄,理說,這裡存放的檔案應該是 /bin 目錄下程式所需要的庫檔案的存放地,也不排除一些例外的情況。

此目錄相當於根檔案系統下的對應目錄(/bin),非啟動系統,非修復系統以及非本地安裝的程式一般都放在此目錄下。管理員使用的非系統必須的可執行檔案存放目錄/sbin),儲存系統管理程式的二進位製檔案,並且這些檔案不是系統啟動或檔案系統掛載/usr目錄或修復系統所必需的。/usr/share在此目錄下不同的子目錄中儲存了同一個作業系統在不同構架下工作時特定應用程式的共享資料(例如程式檔案資訊)。使用者可以找到通常放在/usr/doc或/usr/lib或/usr/man/usr/includeC程式語言編譯使用的標頭檔案Linux 下開發和編譯應用程式所需要的標頭檔案一般都存放在這裡,通過標頭檔案來使用某些庫函數。預設來說這個路徑被新增到了環境變數中,這樣編譯開發程式的時候編譯器會自動搜尋這個路徑,從中找到你的程式中可能包含的標頭檔案。

/usr/local當我們下載一個程式原始碼,編譯並且安裝的時候,如果不特別指定安裝的程式路徑,那麼預設會將程式相關的檔案安裝到這個目錄的對應目錄下。例如,安裝的程式可執行檔案被安裝(安裝實質就是複製)到了/usr/local/bin下面,此程式(可執行檔案)所需要依賴的庫檔案被安裝到了/usr/local/lib目錄下,被安裝的軟體如果是某個開發庫(例如,Gtk等)那麼相應的標頭檔案可能就被安裝到了/usr/local/include中等等。也就是說,這個目錄存放的內容,一般都是我們後來自己安裝的軟體的預設路徑,如果擇了這個預設路徑作為軟體的安裝路徑,被安裝的軟體的所檔案都限制在這個目錄中,其中的子目錄就相應於根目錄的子目錄。這個目錄採用一種特殊的檔案系統格式(proc格式),核心支援這種格式。其中包含了全部虛擬檔案。它們並不儲存在磁碟中,也不佔據磁碟空間(儘管命令ls -c會顯示它們的大小)。當您檢視它們時,您實際上看到的是記憶體裡的資訊,這些檔案助於我們瞭解系統內部資訊。例如:

/opt 可擇的檔案目錄

ADVERTISEMENT

這個目錄表示的是可擇的意思,些自定義軟體包或者第方工具,就可以安裝在這裡。比如在 Fedora Core 5.0 中, OpenOffice 就是安裝在這裡。些我們自己編譯的軟體包,就可以安裝在這個目錄中;通過源碼包安裝的軟體,可以把它們的安裝路徑設定成 /opt 這樣來安裝。這個目錄的作用一點類似 /usr/local 。

/mnt 臨時掛載目錄

這個目錄一般是用於存放掛載儲存裝置的掛載目錄的,比如磁碟,光碟機,網路檔案系統等,當我們需要掛載某個磁碟裝置的時候,可以把磁碟裝置掛載到這個目錄上去,這樣我們可以直接通過訪問這個目錄來訪問那個磁碟了。一般來說,我們最好在 /mnt 目錄下面多建立幾個子目錄,掛載的時候掛載到這些子目錄上面,因為通常我們可能不僅僅是掛載一個裝置吧?

/media 掛載的媒體裝置目錄掛載的媒體裝置目錄,一般外部裝置掛載到這裡,例如 cdrom 等。比如我們插入一個U盤,我們一般會發現, Linux 自動在這個目錄下建立一個 disk 目錄,然後把U盤掛載到這個 disk 目錄上,通過訪問這個 disk 來訪問U盤。

/var 內容經常變化的目錄

此目錄下檔案的大小可能會改變,如緩衝檔案,日誌檔案,快取檔案,等一般都存放在這裡。

/tmp 臨時檔案目錄

該目錄存放系統中的一些臨時檔案,檔案可能會被系統自動清空。的系統直接把 tmpfs 類型的檔案系統掛載到這個目錄上, tmpfs 檔案系統由 Linux 核心支援,在這個檔案系統中的資料,實際上是記憶體中的,由於記憶體的資料斷電易失,當系統重新啟動的時候我們就會發現這個目錄被清空了。

/lost+found 恢復檔案存放的位置

當系統崩潰的時候,在系統修復過程中需要恢復的檔案,可能就會在這裡被找到了,這個目錄一般為空。

以上目錄,是最常見的重要目錄。其中,有些目錄初學者容易混淆,這裡簡單區分一下:

/bin , /sbin 與 /usr/bin , /usr/sbin

/bin 一般存放對於使用者和系統來說“必須”的程式(二進位製檔案)。

/sbin 一般存放用於系統管理的“必需”的程式(二進位製檔案),一般普通使用者不會使用,根使用者使用。

/usr/bin 一般存放的只是對使用者和系統來說“不是必需的”程式(二進位製檔案)。

/usr/sbin 一般存放用於系統管理的系統管理的不是必需的程式(二進位製檔案)。

/lib 與 /usr/lib

/lib 和 /usr/lib 的區別類似 /bin, /sbin 與 /usr/bin, /usr/sbin 。

/lib 一般存放對於使用者和系統來說“必須”的庫(二進位製檔案)。

/usr/lib 一般存放的只是對使用者和系統來說“不是必需的”庫(二進位製檔案)。

其他還一些目錄例如:,,,/usr/local/etc等等,其作用都是類似於,/bin等目錄的,可能只是層次概念不同了,使用 Linux 時間長了,會逐漸體會到其中的含義。當然,我們可以無視這些目錄,像使用Windows那樣自由的,不管啥檔案,想往哪存就往哪存,還是那句話,使用 Linux 時間長了,會逐漸體會到其中的含義,到時候也許我們想要亂來都不行了呢。^_^

對檔案系統目錄的分類標準在大多數 Linux 系統上面,我們可以使用一個命令:man hier,通過這個命令的輸出,就知道“根目錄”中所子目錄的作用了。這個命令含義我不多說了,總之這裡的hier就是對 Linux 檔案系統中各級目錄的標準功能,是一個大家都約定俗成了的東西。想要瞭解每個目錄更詳細的資訊,需要仔細參考man hier的輸出。下面就是一個比較簡短的中文描述的對檔案系統目錄分類的FHS標準,也就是對man hier的簡單翻譯。

小Tips:讀者可以儲存上面這張圖片哦~

作者簡介呂凱,TPV資深主任工程師,大連理工大學碩士。關注軟體開發、系統運維、內容管理、行動管理等領域,喜歡計數寫作及分享。

科技

» 高效開發運維

ADVERTISEMENT