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 08:35
下一篇 2016-10-17 08:36

相关推荐

  • linux文件、目录基本操作命令及bash特性介绍

    1、文件层级FHS介绍: Filesystem Hierarchy Standard(文件系统层次化标准)的缩写,多数Linux版本采用这种文件组织形式,类似于Windows操作系统中c盘的文件目录,FHS采用树形结构组织文件。 FHS定义了系统中每个区域的用途、所需要的最小构成的文件和目录,同时还给出了例外处理与矛盾处理。 /:linux文件系统根目录 /…

    2017-09-17
  • N25_第十三周作业

    1、建立samba共享,共享目录为/data,要求:(描述完整的过程)  1)共享名为shared,工作组为magedu;  2)添加组develop,添加用户gentoo,centos和ubuntu,其中gentoo和centos以develop为附加组,ubuntu不属于develop组;密码均为用户名;  3)添加samb…

    Linux干货 2017-03-06
  • Linux基础知识之软硬链接

    系统环境:    该博文以CentOS6.8_x86_64系统为基础,Xshell5远程登录CentOS6.8系统,以root身份登录系统。 为什么要学习符号(软)链接和硬链接?    符号(软)链接和硬链接是Linux文件系统中的一个重要的概念,软硬链接的学习过程中会涉及一些文件系统中的索引节点(inode),索引节…

    Linux干货 2016-08-02
  • N28-第四周

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。
    2、编辑/etc/group文件,添加组hadoop。
    3、手动编辑/etc/passwd文件新增一行,添加用户hadoop,其基本组ID为hadoop组的id号;其家目录为/home/hadoop。
    4、复制/etc/skel目录为/home/hadoop,要求修改hadoop目录的属组和其它用户没有任何访问权限。
    5、修改/home/hadoop目录及其内部所有文件的属主为hadoop,属组为hadoop。
    6、显示/proc/meminfo文件中以大写或小写S开头的行;用两种方式;
    7、显示/etc/passwd文件中其默认shell为非/sbin/nologin的用户;
    8、显示/etc/passwd文件中其默认shell为/bin/bash的用户;
    9、找出/etc/passwd文件中的一位数或两位数;
    10、显示/boot/grub/grub.conf中以至少一个空白字符开头的行;
    11、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行;
    12、打出netstat -tan命令执行结果中以‘LISTEN’,后或跟空白字符结尾的行;
    13、添加用户bash, testbash, basher, nologin (此一个用户的shell为/sbin/nologin),而后找出当前系统上其用户名和默认shell相同的用户的信息;

    2017-12-30
  • 任务计划和本地系统的默认邮件

    一、前言 二、本地mail的使用方法 三、at /batch 四、cron 五、小结   一、前言 linux 中执行任务计划有三种命令:at ,batch ,cron.其中,at,batch 是一次性执行,而crontab,则是周期性执行; 作业执行完成后,会通过邮件通知给作业提交者;因此,以下就从邮件说起。 二、邮件服务 Centos ,默认会…

    Linux干货 2015-05-13
  • 磁盘管理之文件系统

                             文件系统     文件系统是操作系统用于…

    Linux干货 2016-09-06