FHS文件系统各目录功能

前言


FHS将文件根据不同的用途和特性分成了可共享的(shareable)和不可共享的(unshareable),可变的(variable)和静态的(static)。不同的文件位于不同的目录里面,将目录分开了将有利于对文件的管理。


文件系统


  • 可共享的

文件可以被存储于某一个主机上,然后供其他主机使用。如果想访问其他主机上可共享的文件,可以将其他主机目录挂载到本地目录。如:/usr,/opt等。

  • 不可共享的

不可被共享的,如本地配置文件的。如:/boot,/etc等。

  • 静态的

如lib、bin目录等,除了管理员账户外其他用户都不能访问的文件。静态文件还可以为一些只读设备上面的文件。如:/usr,/etc。

  • 可变的

如/var目录等,用户可以修改的文件。如:/var等。

共享和静态是两个纬度的属性,一个目录可以分别具有两种属性,如/boot目录,为不可共享的且静态的,/urs为可共享的且静态的。

FHS,Filesystem Hierarchy Standard(文件系统目录标准)的缩写,多数Linux版本采用这种文件组织形式。

根目录

根目录需要保证能引导系统启动,且可以恢复、还原、修复系统。

引导启动:根目录存放了程序、配置、引导加载信息等一些必要的信息。

恢复系统:根目录存放了一些诊断和修复程序信息。

还原系统:根目录存放了可以通过备份还原系统的程序信息。

FHS
建议将根目录分区设置得小一点。一方面根目录经常通过比较小的设备安装,没必要太大。另一方面,根目录存放的是系统内核和特定的配置等信息,通常根目录是
不能共享的。较小的根目录空间,可以服务器或工作证只需要比较小的本地空间即可。如果将根目录设置成一个比较大的空间,有可能会出现一些跟根目录较小的程
序不相容的情况。而且根目录存放的是非常重要的文件和信息,较大的空间意味这更有可能出现根目录磁盘损坏的可能。

目录结构

如下的文件目录或目录连接是需要出现在根目录(“/”)下的:

其中,要求存在的有如下目录:

/

|—/bin

|—/boot

|—/dev

|—/etc

|—/lib

|—/media

|—/mnt

|—/opt

|—/sbin

|—/srv

|—/tmp

|—/usr

|—/var

可选择的,而且FHS建议需要有的目录有:

/

|—/home

|—/lib<qual>

|—/root

  • /boot : 静态的引导加载程序

/boot目录是启动过程中非常重要的目。/boot 存放系统在引导过程中需要的所有数据。引导过程不需要的配置、映射程序等可以不在里面。/boo的数据在内核启动用户模式之前就会被用到。/boot 包含了磁盘的主引导程序和文件映射。

操作系统的内核必须在 / 或者 /root 里面。

  • /bin : 基础的用户命令二进制文件

/bin 包含了管理员和用户都会用到的命令。/bin目录下的命令被要求可以在不装载其他文件系统的情况下(单用户模式)使用。/bin目录下同时还包含可以被其他脚本直接应用的命令。


/bin里面常见的必须有的命令有,权限管理(su、pwd、chmod),文件操作(cat、cp、mv、rm),目录操作(ls、mkdir、
rmdir),进程管理(ps、kill)等。还有一些FHS建议需要的命令有网络管理(netstat、ping)、文件压缩(tar)等命令。

为了能兼容LinuxBourne Shell命令,在/bin/sh里面存放的命令实际上不是真正的二进制文件,而是指向了真正能执行的shell命令的链接。

  • /sbin : 系统文件

/sbin 目录存放了供系统管理员使用的命令或工具。/sbin 包含了供系统引导启动、修复、还原的文件。

为了更好的管理命令供某些特定的人使用还是给普通用户使用,同时也是为了做好权限管理和系统安装,划分了/bin 和 /sbin 两个目录。一般情况下,如果普通用户都会用到的指令就会放到 /bin 下面。除非特定的用户或用户组,不然禁止使用 /sbin下的指令。

  • /lib : 基础共享库函数和内核模块

/lib 目录存放了在引导启动以及执行root命令需要的二进制文件。

  • /lib<qual> : 用户替换的基础库函数

/lib<qual> 为 /lib 目录下的一种或多种格式,用于支持多种文件格式(32位或64位)的库函数。

一般情况下/lib<qual> 目录会被命名为 /lib32 或 /lib64 。

  • /dev : 设备文件

/dev 目录存放了设备文件。

  • /etc : 基于主机的系统配置

/etc 目录存放配置文件。/etc 存放的配置文件指的是本地的配置。/etc 存放的是可以控制程序的运行配置,不允许在/etc 目录下存放可执行的文件。

  • /opt : 附加程序的软件包

/opt
安装附加程序的软件包的目录。软件包安装到/opt
下时,静态文件都被放到/opt/<package>(package为软件的名称)目录下。/opt的几个子目录/opt/bin,
/opt/doc, /opt/include, /opt/info, /opt/lib,
/opt/man是预留给本地管理员使用的。/opt底下的软件如果有变量则安装在/var/opt里面,如果有配置则安装在/etc/opt 里面。

  • /root : root用户的home目录

/root 目录是root账户的home目录,一般情况下不建议除了管理员账户之外的其他用户访问和使用。

  • /home : 用户目录

/home是基于站点的文件系统,根据不同站点内容可能不一样。因此,程序设计的时候不要依赖于/home目录的存储位置。

例如小系统可能在/home目录底下会根据用户划分子目录,如/home/jack、/home/tom等。大型一点的服务器系统,在/home 目录底下会先划分用户组在划分用户子目录,如/home/guest/jack等。

  • /usr : 系统软件资源

usr为Unix Software Resource的缩写,存放了系统的软件资源。管理员安装的软件主要存放在/usr目录下。所以/usr 是一个占用空间比较大的目录。

/usr 为一个可共享、只读的文件夹,也就是说在两个符合FHS标准的主机间,/usr可以被共享,但是不能被写入信息。所以基于本机的数据不允许放在/usr底下,同时/usr尽量不要存放较大的文件。

/usr下有几个子目录比较重要:

/usr/bin:多数用户命令

/usr/lib:软件或程序的库文件

/usr/sbin: 不太重要的系统指令

  • /var : 动态文件目录

/var 存放了动态数据,如系统缓存、日志文件、临时文件等。

  • /srv : 本系统为网络服务提供的数据

/srv 包含了本系统为网络服务提供的数据。/srv 目录方便用户通过网络查找并范围本地的数据,同时也为本地数据能根据只读、可写、脚本等划分不同的目录。

目前为止,/srv 目录下的子目录没有标准,如可以通过协议命名 /srv/www,/srv/ftp,如果是大型服务器,也可以根据业务内心划分,如/srv/physics/www等。所以程序在运行的过程中,不能依赖于/srv的目录结构。

  • /media : 移动装置挂载点

/media作为移动装置的挂载点(如软盘、CD roms等)。有时候也会以/mnt、/cdrom等目录作为装置的挂载点,如果全部挂载到根目录 / 下,会导致根目录存在大量的移动装置子目录了。有时候也会将/mnt 作为移动装置的临时挂载点。

常见的目录有/media/cdrom,/media/floppy 等。

  • /mnt : 临时挂载目录的挂载点

/mnt 目录作可以在管理员需要的时候作为临时的挂载点。 /mnt 不能被需要安装的程序所用。

  • /tmp : 临时文件目录 /

/tmp 作为程序在运行过程中临时文件的地方,运行程序不要串改了其他程序的文件。

/tmp 重启后可能会被系统清除掉,所以要重要的信息要保存到其他地方。

原创文章,作者:Zero,如若转载,请注明出处:http://www.178linux.com/52024

(2)
ZeroZero
上一篇 2016-10-17
下一篇 2016-10-17

相关推荐

  • yum安装报错

    我的系统是centos 6.8 x86 安装bind时出错如下: [root@Ams ~]# yum install bind -y Loaded plugins: fastestmirror, refresh-packagekit, security Setting up Install Process Loading mirror speeds from…

    Linux干货 2016-08-02
  • Linux任务计划命令及应用

    at命令,crontab命令

    2018-03-12
  • N22-第二周作业-对Linux的基础操作命令的理解及用法示例

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 Linux上文件管理类命令常用的有:pwd、ls、cd、cp、touch、mv、rm、rmdir   1)pwd:显示当前工作目录     2)ls:列出指定目录下的内容    常用的选项有:   -a:列出目录中的所有文…

    Linux干货 2016-08-22
  • 使用sudo对用户进行权限管理

    使用sudo对用户进行权限管理 因为root用户权限太大,一般在实际应用的时候 ,为了避免造成错误泛滥和找不到责任人都需要对使用服务器人员进行权限分配,除了系统管理员外,其他人禁止使用root,但可以通过sudo命令,给自己提权。同时通过日志审计进行监控操作,操作如下: 1.禁止普通用户使用su命令到root # usermod -g wheel user0…

    Linux干货 2017-03-26
  • 文件查找、压缩、归档

    一、文件查找 非实时查找(数据库查找)locate;实时查找find locate:从系统上预建的文件索引数据库 /var/lib/mlocate/mlocate.db查找,但是依赖于事先构建的索引; 索引的构建是在系统较为空闲时自动进行,管理员手动的更新数据库(updatedb),得用updatedb命令跟新数据库,才能快速查找,也要根据权限搜索…

    Linux干货 2016-11-27
  • Linux 用户, 组和权限

    用户, 组和权限 Linux登陆需要用户名、密码。/etc/passwd 文件保存用户名。登录linux时,Linux 先查找 /etc/passwd 文件中是否有这个用户名,没有则跳出,有则读取用户名的user ID 、 group ID 、用户名对应的根目录路径以及所使用的 shell ,最后在 /etc/shadow 中核对该 UI…

    2017-07-22