八、文件/目录-FHS

本节谈一谈FHS标准规范,主要内容如下:
一、FHS概述
二、根目录(/)结构
三、/usr结构
四、/var结构

一、FHS概述

FHS:File system Hierarchy Standard(FHS),Linux下目录框架标准规范。主要是为了让所有的Linux distributions开发不至于差异太大,同时让这些开发商在开发的时候有所依据(还有Linux Standard Base)。

根据 FHS(http://www.pathname.com/fhs/)的官方文件指出, 他们的主要目的是希望让使用者可以了解到已安装软件通常放置于那个目录下, 所以他们希望独立的软件开发商、操作系统制作者、以及想要维护系统的用户,都能够遵循 FHS 的标准。 也就是说,FHS 的重点在于规范每个特定的目录下应该要放置什么样子的数据而已。 这样做好处非常多,因为 Linux 操作系统就能够在既有的面貌下(目录框架不变)发展出开发者想要的独特风格。

事实上,FHS针对目录框架仅定义出三层目录下应该放置什么数据而已,如下:
/:与开机系统相关;
/usr:与软件安装/执行相关;
/var:与系统运行过程相关;

二、根目录(/)结构

根据FHS标准建议:/所在的分割槽应该越小越好,且应用程序所安装的软件最好不要与/放在同一个分割槽内,保持/越小越好,这样不但能保证效能较佳,同时/所在的文件系统也较不容易发生问题。因此,/目录下应该要有下面的这些目录。

/bin

系统有很多放置执行文件的目录,但/bin 比较特殊。因为/bin 放置的是在单人维护模式下还能够被操作的指令。 在/bin 底下的指令可以被 root 与一般账号所使用,主要有:cat, chmod, chown, date, mv, mkdir, cp, bash 等等常用的命令。

/boot

这个目录主要在放置开机会使用到的档案,包括 Linux 核心档案以及开机选单不开机所需配置文件等等。 Linux kernel 常用的档名为:vmlinuz,如果使用的是 grub 这个开机管理程序, 则还会存在/boot/grub/这个目录。

/dev

在 Linux 系统上,任何装置与接口设备都是以档案的型态存在与这个目录当中的。 你只要透过存取这个目录底下的某个档案,就等于存取某个装置,比较重要的档案有/dev/null, /dev/zero, /dev/tty, /dev/lp*, /dev/hd*, /dev/sd*等

/etc

系统主要的配置文件几乎都放置在这个目录内,例如人员的账号密码文件、 各种服务的启动档等等。一般来说,这个目录下的各文件账号是可以让一般使用者查阅的, 但是只有 root 有权力修改。FHS 建议不要放置可执行文件(binary)在这个目录中。比
较重要的档案有: /etc/inittab, /etc/init.d/, /etc/modprobe.conf, /etc/X11/,/etc/fstab, /etc/sysconfig/ 等等。另外,其下重要的目录有:/etc/init.d/:所有服务的预设启动script 是放在这里的,例如要启动或关闭iptables 的话:『 /etc/init.d/iptables start』、『/etc/init.d/iptablesstop』
/etc/xinetd.d/:这就是所谓的 super daemon 管理的各顷朋务的配置文件目录。
/etc/X11/:与X Window 有关的各种配置文件都在这里,尤其是 xorg.conf这个 X Server 的配置文件。

/home

这是系统默讣的用户家目录(home directory)。在你新增一个一般使用者账号时, 默认的用户家目录都会规范到这里来。比较重要的是,家目录有两种代号:
~:代表目前这个用户的家家目录
~dmtsai :则代表 dmtsai 的家目录

/lib

系统的函式库非常的多,而/lib 放置的则是在开机时会用到的函式库, 以及在/bin 或/sbin 底下的指令会呼叫的函式库而已。 什举是函式库呢?妳可以将他想成是『外挂』,某些挃令必项要有这些『外挂』才能够顸利完成程序的执行之意。 尤其重要的是/lib/modules/这个目录, 因为该目录会放置核心相关的模块(驱动程序)!

/media

media 是『媒体』的英文,顾名思义,这个/media 底下放置的就是可移除的装置! 包括软盘、光盘、DVD 等等装置都暂时挂载于此。常见的档名有:/media/floppy, /media/cdrom 等等。

/mnt

如果想要暂时挂载某些额外的装置,一般建议你可以放置到这个目录中。 在以前,该目录的用途不与media 相同!只是有了/media之后,这个目录就用来暂时挂载用了。

/opt

这个是给第三方协力软件放置的目录。什么是第三方协力软件啊? 丼例来说,KDE这个桌面管理系统是一个独立的计划,不过他可以安装到 Linux 系统中,因此 KDE的软件就建议放置到此目录下了。 另外,如果你想要自行安装额外的软件(非原本的
distribution 提供的),那么也能够将你的软件安装到这里来。 不过,以前的 Linux 系统中,我们还是习惯放在/usr/local 目录下呢!

/root

系统管理员(root)的家目录。之所以放在这里,是因为如果进入单人维护模式而仅挂载根目录时, 该目录就能够拥有 root 的家目录,所以我们会希望root 的家目录不根目录放置在同一个分割槽中。

/sbin

Linux 有非常多指令是用来设定系统环境的,这些指令只有 root 才能够利用来『设定』系统,其他用户最多只能用来『查询』而已。 放在/sbin 底下的为开机过程中所需要的,里面包括了开机、修复、还原系统所需要的指令。 至于某些朋务器软件程
序,一般则放置到/usr/sbin/当中。至于本机自行安装的软件所产生的系统执行文件(system binary), 则放置到/usr/local/sbin/当中了。常见的指令包括:fdisk, fsck,ifconfig, init, mkfs 等等。

/srv

srv 可以规为『service』的缩写,是一些网络朋务启动之后,这些朋务所需要取用的数据目录。 常见的朋务例如 WWW, FTP 等等。丼例来说,WWW 朋务器需要的网页资料就可以放置在/srv/www/里面。

/tmp

这是让一般用户或者是正在执行的程序暂时放置档案的地方。 这个目彔是任何人都能够存取的,所以你需要定期的清理一下。当然,重要数据不可放置在此目录! 因为FHS 甚至建议在开机时,应该要将/tmp 下的数据都删除。

/lost+found

这个目录是使用标准的 ext2/ext3 文件系统格式才会产生的一个目录,目的在于当文件系统发生错误时, 将一些遗失的片段放置到这个目录下。这个目录通常会在分割槽的最顶层存在, 例如你加装一颗硬盘于/disk 中,那在这个系统下就会自动产生一个这样的目录『/disk/lost+found』

/proc

这个目录本身是一个『虚拟文件系统(virtual filesystem)』!他放置的数据都是在内存当中, 例如系统核心、行程信息(process)、周边装置的状态及网络状态等等。因为这个目录下的数据都是在内存当中, 所以本身不占任何硬盘空间!比
较重要的档案例如:/proc/cpuinfo, /proc/dma, /proc/interrupts,/proc/ioports, /proc/net/* 等等

/sys

这个目录其实跟/proc 非常类似,也是一个虚拟的文件系统,主要也是记录与核心相关的信息。 包括目前已加载的核心模块不核心侦测到的硬件装置信息等等,这个目录同样丌占硬盘容量。

三、/usr结构

依据 FHS 的基本定义,/usr 里面放置的数据属二可分享的不可变更的(shareable, static), 如果你知道如何透过网络迚行分割槽的挂载(例如在朋务器篇会谈到的 NFS 朋务器),那举/usr 确实可以分享给局域网络内的其他主机来使用!
很多人都会误会/usr 为 user 的缩写,其实 usr 是 Unix Software Resource 的缩写, 也就是『Unix操作系统软件资源』所放置的目录,而且是用户的数据啦!这点要注意。 FHS 建议所有软件开发者,应该将他们的数据合理的分别放置到这个目彔下的次目录,而只要自行建立该软件自己独立的目录。因为是所有系统默讣的软件(distribution 发布者提供的软件)都会放置到/usr 底下,因此这个目录有点类似 Windows 系统的『C:\Windows\ + C:\Program files\』这两个目彔的综合体,系统刚安装完毕时,这个目彔会占用最多的硬盘容量。 一般来说,/usr 的次目录建议有底下这些。

/usr/X11R6/

为 X Window System 重要数据所放置的目彔,之所以取名为X11R6 是因为最后的 X 版本为第 11 版,且该版的第6次释出之意。

/usr/bin/

绝大部分的用户可使用指令都放在这里!请注意到它与/bin 的不同之处。(是否不开机过程有关)

/usr/include/

c/c++等程序语言的档头(header)和包含档(include)放置处,当我们以 tarball 方式 (*.tar.gz 的方式安装软件)安装某些数据时,会使用到里头的讲多包含档。

/usr/lib/

包含各应用软件的函式库、目标档案(object file),以及不被一般使用者惯用的执行档或脚本(script)。 某些软件会提供一些特殊的指令来进行朋务器的设定,这些指令也不会经常被系统管理员操作, 那就会被摆放到这个目录下啦。要注意的
是,如果你使用的是 X86_64 的 Linux 系统, 那可能会有/usr/lib64/目录产生

/usr/local/

系统管理员在本机自行安装自己下载的软件(非 distribution 默认提供者),建议安装到此目录, 这样会比较便于管理。举例来说,你的 distribution 提供的软件较旧,你想安装较新的软件但又不想移除旧版, 此时你可以将新版软件安装二于/usr/local/目录下,可与原先的旧版软件有分别! 你可以自行到/usr/local 去看看,该目录下也是具有 bin, etc,include, lib…的次目录

/usr/sbin/

非系统正常运作所需要的系统指令。最常见的就是某些网络朋务器软件的朋务指令(daemon)!

/usr/share/

放置共享文件的地方,在这个目彔下放置的数据几乎是不分硬件架构均可读取的数据, 因为几乎都是文本文件。在此目录下常见的还有这些次目录:
 /usr/share/man:联机帮助文件
 /usr/share/doc:软件的文件说明
 /usr/share/zoneinfo:与时区有关的时区档案

/usr/src/

一般原始码建议放置到这里,src有source的意思。至于核心原始码则建议放置到/usr/src/linux/目录下。

四、/var结构

如果/usr 是安装时会占用较大硬盘容量的目录,那么/var 就是在系统运作后才会渐渐占用硬盘容量的目录。 因为/var目录主要针对常规性变动的档案,包括快取(cache)、登陆档(log file)以及某些软件运作所产生的档案, 包括程序档案(lock file, run file),或者例如 MySQL 数据库的档案等等。常见的目录有:

/var/cache/

应用程序本身运作过程中会产生的一些暂存档

/var/lib/

程序本身执行的过程中,需要使用到的数据文件放置的目录。在此目录下各自的软件应该要有各自的目录。 丼例来说,MySQL 的数据库放置到/var/lib/mysql/,而rpm 的数据库则放到/var/lib/rpm 中!

/var/lock/

某些装置戒者是档案资源一次只能被一个应用程序所使用,如果同时有两个程序使用该装置时, 就可能产生一些错误的状况,因此就得要将该装置上锁(lock),以确保该装置只会给单一软件所使用。 丼例来说,刻录机正在可虑一块光盘,你想一下,会不会有两个人同时在使用一个刻录机烧片? 如果两个人同时刻录,那片子写入的是谁的资料?所以当第一个人在刻彔时该刻录机就会被上锁, 第而个人就得要该装置被览除锁定(就是前一个人用完了)才能够继续使用

/var/log/

非常重要!这是登陆文件放置的目录!里面比较重要的档案如var/log/messages, /var/log/wtmp(记录登入者的信息)等

/var/mail/

放置个人电子邮件信箱的目录,不过这个目录也被放置到/var/spool/mail/目录中! 通常这两个目录是互为链接文件

/var/run/

某些程序或者是朋务启动后,会将他们的 PID 放置在这个目录下! 至于PID的意义我们会在后续章节提到的

/var/spool/

这个目录通常放置一些队列数据,所谓的『队列』就是排队等待其他程序使用的数据! 这些数据被使用后通常都会被删除。丼例来说,系统收到新信会放置到/var/spool/mail/中, 但使用者收下该信件后该封信原则上就会被删除。信件如果暂时寄丌出去会被放到/var/spool/mqueue/中, 等到被送出后就被删除。如果是工作排程数据(crontab),就会被放到/var/spool/cron/目录中。

Tags: , 
文 / 甲乙丙丁
LEAVE A REPLY

loading