Linux之目录结构配置

Posted program_Li

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux之目录结构配置相关的知识,希望对你有一定的参考价值。

因为 Linux 的开发者实在太多了,如果每个人都发展出属于自己的目录配置方法, 那么将可能会造成很多管理上的困扰。所以,就有一个叫做Filesystem Hierarchy Standard (FHS) 标准的出来了。

这个 FHS ( http://www.pathname.com/fhs/ ) 事实上仅是规范出在根目录 ( / ) 底下各个主要的目录应该是要放置什么样的档案而已。 FHS 定义出两层规范出来,第一层是 / 底下的各个目录应该要放置什么样内容的档案数据,例如 /etc 应该要放置配置文件, /bin 与 /sbin 则应该要放置可执行文件等等。第二层则是针对 /usr 及 /var 这两个目录的次目录来定义的。 例如 /var/log 放置系统注册表档、 /usr/share 放置共享数据等等。
事实上,FHS是根据过去的经验一直再持续的改版的,FHS依据文件系统使用的频繁与否与是否允许使用者随意更动, 而将目录定义成为四种交互作用的形态,用表格来说有点像底下这样:

  可分享的(shareable) 不可分享的(unshareable)
不变的(static) /usr (软件放置处) /etc (配置文件)
  /opt (第三方协力软件) /boot (开机与核心档)
可变动的(variable) /var/mail (使用者邮件信箱) /var/run (程序相关)
  /var/spool/news (新闻组) /var/lock (程序相关)
  • 可分享的:可以分享给其他系统挂载使用的目录,所以包括执行文件与用户的邮件等数据, 是能够分享给网络上其他主机挂载用的目录;
  • 不可分享的:自己机器上面运作的装置文件或者是与程序有关的socket文件等, 由于仅与自身机器有关,所以当然就不适合分享给其他主机了。
  • 不变的:有些数据是不会经常变动的,跟随着distribution而不变动。 例如函式库、文件说明文件、系统管理员所管理的主机服务配置文件等等;
  • 可变动的:经常改变的数据,例如登录文件、一般用户可自行收受的新闻组等。

我们可以通过ls -l / 这个命令来看一下【/】根目录下的目录配置结构:

root@Ubuntu1604:/# ll /
total 112
drwxr-xr-x  25 root root  4096 9月   8 11:33 ./
drwxr-xr-x  25 root root  4096 9月   8 11:33 ../
drwxr-xr-x   2 root root  4096 5月  24 13:50 bin/
drwxr-xr-x   3 root root  4096 9月   8 11:34 boot/
drwxrwxr-x   2 root root  4096 10月 30  2017 cdrom/
drwxr-xr-x  18 root root  3960 9月   8 18:43 dev/
drwxr-xr-x 131 root root 12288 9月   8 16:44 etc/
drwxr-xr-x   5 root root  4096 9月   8 16:39 home/
lrwxrwxrwx   1 root root    33 9月   8 11:33 initrd.img -> boot/initrd.img-4.4.0-134-generic
lrwxrwxrwx   1 root root    33 7月   9 14:34 initrd.img.old -> boot/initrd.img-4.4.0-130-generic
drwxr-xr-x  22 root root  4096 6月  11 09:33 lib/
drwxr-xr-x   2 root root  4096 6月  11 09:33 lib32/
drwxr-xr-x   2 root root  4096 5月  24 13:50 lib64/
drwx------   2 root root 16384 10月 30  2017 lost+found/
-rw-r--r--   1 root root     0 12月  7  2017 main.c
drwxr-xr-x   3 root root  4096 10月 30  2017 media/
drwxr-xr-x   2 root root  4096 7月  20  2016 mnt/
drwxr-xr-x   2 root root  4096 7月  20  2016 opt/
dr-xr-xr-x 182 root root     0 9月   8 18:43 proc/
drwx------  17 hwli root  4096 9月   8 16:41 root/
drwxr-xr-x  24 root root   740 9月   8 18:44 run/
drwxr-xr-x   2 root root 12288 9月   8 11:33 sbin/
drwxr-xr-x   2 root root  4096 6月  30  2016 snap/
drwxr-xr-x   2 root root  4096 7月  20  2016 srv/
dr-xr-xr-x  13 root root     0 9月   8 18:43 sys/
drwxrwxrwt   8 root root  4096 9月   8 18:44 tmp/
drwxr-xr-x  12 root root  4096 6月  11 09:33 usr/
drwxr-xr-x  14 root root  4096 7月  20  2016 var/
lrwxrwxrwx   1 root root    30 9月   8 11:33 vmlinuz -> boot/vmlinuz-4.4.0-134-generic
lrwxrwxrwx   1 root root    30 7月   9 14:34 vmlinuz.old -> boot/vmlinuz-4.4.0-130-generic
root@Ubuntu1604:/#

现在看到前面那些个属性我们是不是已经非常熟悉了呢?

如果要以较为完整的树状目录来看,整个Linux系统的树状目录可以用下图来表示:

 

我们可以看到,所有的这些目录都是依附在了【/】根目录下面,这也就是我们俗称的"树状目录"。根据FHS定义,每个目录内应该放置的文件内容应如下所示:

目录 应放置文件内容
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 "Editable Text Configuration"的简写。系统主要的配置文件几乎都放置在这个目录内,例如人员的账号密码文件、 各种服务的启始档等等。一般来说,这个目录下的各文件属性是可以让一般使用者查阅的, 但是只有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/iptables stop"
  • /etc/xinetd.d/:这就是所谓的super daemon管理的各项服务的配置文件目录。
  • /etc/X11/:与 X Window 有关的各种配置文件都在这里,尤其是 xorg.conf 这个 X Server 的配置文件。
/home 这是系统默认的用户家目录(home directory)。在你新增一个一般使用者账号时, 默认的用户家目录都会规范到这里来。比较重要的是,家目录有两种代号: ~:代表目前这个用户的家目录,而 ~vbird :则代表 vbird 的家目录!
/lib "library"的简写。系统的函式库非常的多,而/lib放置的则是在开机时会用到的函式库, 以及在/bin或/sbin底下的指令会呼叫的函式库而已。 什么是函式库呢?你可以将他想成是『外挂』,某些指令必须要有这些『外挂』才能够顺利完成程序的执行之意。 尤其重要的是/lib/modules/这个目录, 因为该目录会放置核心相关的模块(驱动程序)!
/media media是『媒体』的英文,顾名思义,这个/media底下放置的就是可移除的装置啦! 包括软盘、光盘、DVD等等装置都暂时挂载于此。常见的档名有:/media/floppy, /media/cdrom等等。(我们的光盘镜像文件通常都是挂载在了media这个目录下)
/mnt "mount"的简写。如果你想要暂时挂载某些额外的装置,一般建议妳可以放置到这个目录中。 在古早时候,这个目录的用途与/media相同啦!只是有了/media之后,这个目录就用来暂时挂载用了。
/opt "Optional application software packages"的简写。这个是给第三方协力软件放置的目录。什么是第三方协力软件啊? 举例来说,KDE这个桌面管理系统是一个独立的计划,不过他可以安装到Linux系统中,因此KDE的软件就建议放置到此目录下了。 另外,如果妳想要自行安装额外的软件(非原本的distribution提供的),那么也能够将你的软件安装到这里来。 不过,以前的Linux系统中,我们还是习惯放置在/usr/local目录下呢!
/root 系统管理员(root)的家目录。之所以放在这里,是因为如果进入单人维护模式而仅挂载根目录时, 该目录就能够拥有root的家目录,所以我们会希望root的家目录与根目录放置在同一个分割槽中。
/sbin "Superuser Binaries"的简写。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下的数据都删除唷
非FHS规定的目录
/lost+found 这个目录是使用标准的ext2/ext3文件系统格式才会产生的一个目录,目的在于当文件系统发生错误时, 将一些遗失的片段放置到这个目录下。这个目录通常会在分割槽的最顶层存在, 例如你加装一颗硬盘于/disk中,那在这个系统下就会自动产生一个这样的目录『/disk/lost+found』
/proc "Processes"的简写。这个目录本身是一个『虚拟文件系统(virtual filesystem)』喔!他放置的数据都是在内存当中, 例如系统核心、行程信息(process)、周边装置的状态及网络状态等等。因为这个目录下的数据都是在内存当中, 所以本身不占任何硬盘空间!比较重要的文件例如:/proc/cpuinfo, /proc/dma, /proc/interrupts, /proc/ioports, /proc/net/* 等等。
/sys 这个目录其实跟/proc非常类似,也是一个虚拟的文件系统,主要也是记录与核心相关的信息。 包括目前已加载的核心模块与核心侦测到的硬件装置信息等等。这个目录同样不占硬盘容量
/usr "Unix Shared Resources"的简写由 FHS 规范的第二层内容,在 /usr 此目录下,包含系统的主要程序、 图形接口所需要的档案、额外的函式库、本机端所自行安装的软件,以及共享的目录与文件等等, 都可以在这个目录当中发现。事实上,他有点像是 Windows 操作系统当中的『Program files』与 『WinNT』这两个目录的结合!在此目录下的重要次目录有:
  • /usr/bin, /usr/sbin:一般身份用户与系统管理员可执行的档案放置目录;
  • /usr/include:c/c++等程序语言的档头 (header) 与包含档(include)放置处, 当我们以 tarball 方式 (*.tar.gz 的方式安装软件) 安装某些数据时,会使用到里头的许多包含档喔!;
  • /usr/lib:各应用软件的函式库档案放置目录;
  • /usr/local:本机端自行安装的软件默认放置的目录。目前也适用于 /opt 目录。 在你安装完了 Linux 之后,基本上所有的配备你都有了,但是软件总是可以升级的, 例如你要升级你的 proxy 服务,则通常软件默认的安装地方就是在 /usr/local (local 是『当地』的意思),同时,安装完毕之后所得到的执行文件,为了与系统原先的执行文件有分别, 因此升级后的执行档通常摆在 /usr/local/bin 这个地方。
  • /usr/share:共享文件放置的目录,例如底下两个目录:
  • /usr/share/doc:放置一些系统说明文件的地方,例如你安装了 grub 了,那么在该目录底下找一找,就可以查到 grub 的说明文件了!很是便利!
  • /usr/share/man:manpage 的文件档案目录;在使用 man 的时候,会去查询的路径!例如你使用 man ls 这个指令时,就会查出 /usr/share/man/man1/ls.1.gz 这个说明档的内容!
  • /usr/src:Linux 系统相关的程序代码放置目录,例如 /usr/src/linux 为核心原代码!
  • /usr/X11R6:系统内的 X Window System 所需的执行档几乎都放在这!
 /var  "Variable"的简写这个目录也很重要,也是 FHS 规范的第二层目录内容。他主要放置的是针对系统执行过程中, 常态性变动的档案放置的目录。举例来说,例如缓存文件 (cache) 或者是随时变更的登录文件 (log file) 都是放在这个目录中的。此外,某些软件执行过程中会写入的数据库档案, 例如 mysql 数据库,也都写入在这个目录中!底下的重要目录有:
  • /var/cache:程序档案在运作过程当中的一些暂存盘;
  • /var/lib:程序本身执行的过程中,需要使用到的数据文件放置的目录, 举例来说, locate 这个数据库与 MySQL 及 rpm 等数据库系统,都写在这个目录内。
  • /var/log:登录文件放置的目录。很重要啊!例如 /var/log/messages 就是总管所有登录档的一个档案!
  • /var/lock:某些装置具有一次性写入的特性,例如 tab (磁带机), 此时,为了担心被其他人干扰而破坏正在运作的动作,因此,会将该装置 lock (锁住)起来, 以确定该装置只能被单一个程序所使用!
  • /var/run:某些程序或者是服务启动后,会将他们的 PID 放置在这个目录下!
  • /var/spool:是一些队列数据存放的地方。举例来说,主机收到电子邮件后, 就会放置到 /var/spool/mail 当中,若信件暂时发不出去,就会放置到 /var/spool/mqueue 目录下, 使用者工作任务分配 (cron) 则是放置在 /var/spool/cron 当中!

特别重要的几个目录

  • /etc:这个目录是系统配置文件放置的地方, 包括您系统上的账号与密码 (/etc/passwd, /etc/shadow),还有开机时所要用到的各项设定值 (/etc/sysconfig/*) ,还有各主要的网络服务的配置文件,都在这个目录中。 意思就是说,如果这个目录底下的档案被删除或者是死掉了, 我们就要花费大量的时间来恢复这个目录的文件。因此,一般建议将这个目录进行备份!
  • /usr/local:虽然说目前已经将这个目录的重要性移动到 /opt 了, 但我还是是比较习惯将我自己开发或自行额外安装的软件放置在这个 /usr/local 目录下。 如果你的 Linux 系统是多人共管的话,那么,养成一个良好的操作习惯是有必要的。 那么安装软件的习惯也要好好建立起来啊~不要随意安装呢! 统一放置在 /usr/local 或者是 /opt 底下吧!
  • /var: 这个目录是在管理系统运作过程中的重要中间暂存数据的,例如 /var/lib 与 /var/run 。 此外,最终的数据例如邮件 /var/spool/mail 也是放置在这个目录中  另外,几乎所有服务的登录文件 (可以记录谁、什么时候、由哪里登入主机、做了什么事等等信息!) 都放在 /var/log 这个目录下,因此,这个目录也很重要。

  参考资料:

  https://www.cnblogs.com/xiaoluo501395377/archive/2013/04/20/3033131.html

以上是关于Linux之目录结构配置的主要内容,如果未能解决你的问题,请参考以下文章

Linux之目录结构

Linux运维第九课----目录结构之etc目录内容

Linux基础之 ---目录结构

系统加固之Linux安全加固

Jmeter之目录结构

Linux命令之帮助命令