linux系统各个文件夹作用

本文详细介绍了Linux下各文件夹的意义,包括/bin、/lib、/etc、/mnt、/boot、/sbin、/root、/dev、/tmp、/var、/lost+found、/proc、/usr和/var等目录的功能与用途,以及/proc文件系统的特殊性质。
原文链接:http://blog.chinaunix.net/uid-22018363-id-407691.html
1.linux下各文件夹的意义:
    /bin:是binary的缩写,包含了引导系统启动所需的命令和普通用户可以使用的常用命令
    /lib:是根文件系统目录下程序和核心模块的共享库,存放了根文件系统程序
    运行所需的共享文件。这些文件包含了可被许多程序共享的代码
    以避免每个程序都包含有相同的子程序的副本
    故可以使得可执行文件变得更小,节省空间。
    /etc:用来存放所有的系统管理所需要的配置文件和子目录,linux正是因为这些文件才能正常运行
    /mnt:这个目录是空的,系统提供这个目录是让用户临时挂载别的文件系统
    /boot:这里存放的是启动LINUX时使用的一些核心文件,引导加载器(bootstrap loader)如LILO
    会使用这些文件,当计算机启动时这些文件首先被装载。这个目录也会包含LINUX核(压缩文件 vmlinuz)
    但LINUX核也可以存在别处,只要配置LILO并且LILO知道LINUX核在哪儿。
    
    /sbin:s就是Super User的意思,/sbin目录类似/bin ,也用于存储二进制文件。
    但其中的大部分文件多是系统管理员使用的基本的系统管理程序
    所以虽然普通用户必要且允许时可以使用,但一般不给普通用户使用。 
    /root 系统管理员(超级用户或根用户)的主目录。
    /dev:这个目录下是所有LINUX的外部设备文件,其功能类似DOS下的.sys和Win下的.vxd,用户可以
    通过这些文件访问外部设备,在LINUX中设备和文件是用同种方法访问的。例如:/dev/hda代表第一个物理IDE硬盘。
    /tmp:用于存放临时文件。引导启动后运行的程序应该使用/var/tmp ,而不是/tmp
    因为前者可能在一个拥有更多空间的磁盘上而该目录会被自动清理干净。
    /var:这个目录中存放着那些不断在扩充着的东西,为了保持/usr的相对稳定
    那些经常被修改的目录可以放在这个目录下,实际上许多系统管理员都是这样干的
    顺带说一下系统的日志文件就在/var/log目录中。
    /lost+found:这个目录平时是空的,当系统不正常关机后
    这里就成了一些无家可归的文件的避难所。
    有点类似于DOS下的.chk文件。
    /proc:这个目录是一个虚拟的目录,它是系统内存的映射,我们可以通过直接访问这个目录来获取系统信息
    也就是说,这个目录的内容不在硬盘上而是在内存里啊!
    
    /usr 最庞大的目录,要用到的应用程序和文件几乎都在这个目录
    /usr/x11r6 存放x window的目录 
    /usr/bin 众多的应用程序
/usr/sbin 超级用户的一些管理程序
/usr/doc linux文档
/usr/include linux下开发和编译应用程序所需要的头文件                                                                 
    /usr/lib 常用的动态链接库和软件包的配置文件
/usr/man 帮助文档
/usr/src linux的开放源代码,比如linux内核的源代码就放在/usr/src/linux里
/usr/local/bin 本地增加的命令
/usr/local/lib 本地增加的库
    
    
    
    2.下面详细介绍;
/etc文件系统
/etc 目录包含各种系统配置文件,下面说明其中的一些。其他的你应该知道它们属于哪个
程序,并阅读该程序的m a n页。许多网络配置文件也在/etc 中。
1. /etc/rc或/etc/rc.d或/etc/rc?.d
启动、或改变运行级时运行的脚本或脚本的目录。
2. /etc/passwd
用户数据库,其中的域给出了用户名、真实姓名、用户起始目录、加密口令和用户的其
他信息。
3. /etc/fdprm
软盘参数表,用以说明不同的软盘格式。可用setfdprm 进行设置。更多的信息见s e t f d p r m
的帮助页。
4. /etc/fstab
指定启动时需要自动安装的文件系统列表。也包括用swapon -a启用的s w a p区的信息。
5. /etc/group
类似/etc/passwd ,但说明的不是用户信息而是组的信息。包括组的各种数据。
6. /etc/inittab
init 的配置文件。
7. /etc/issue
包括用户在登录提示符前的输出信息。通常包括系统的一段短说明或欢迎信息。具体内
容由系统管理员确定。
8. /etc/magic
“f i l e”的配置文件。包含不同文件格式的说明,“f i l e”基于它猜测文件类型。
9. /etc/motd
m o t d是message of the day的缩写,用户成功登录后自动输出。内容由系统管理员确定。
常用于通告信息,如计划关机时间的警告等。
10. /etc/mtab
当前安装的文件系统列表。由脚本( s c r i t p )初始化,并由mount 命令自动更新。当需要一
个当前安装的文件系统的列表时使用(例如df 命令)。
11. /etc/shadow
在安装了影子( s h a d o w )口令软件的系统上的影子口令文件。影子口令文件将/ e t c / p a s s w d
文件中的加密口令移动到/ e t c / s h a d o w中,而后者只对超级用户( r o o t )可读。这使破译口令更困
难,以此增加系统的安全性。
12. /etc/login.defs
l o g i n命令的配置文件。
13. /etc/printcap
类似/etc/termcap ,但针对打印机。语法不同。
14. /etc/profile 、/ e t c / c s h . l o g i n、/etc/csh.cshrc
登录或启动时b o u r n e或c shells执行的文件。这允许系统管理员为所有用户建立全局缺省环境。
15. /etc/securetty
确认安全终端,即哪个终端允许超级用户( r o o t )登录。一般只列出虚拟控制台,这样就不
可能(至少很困难)通过调制解调器( m o d e m )或网络闯入系统并得到超级用户特权。
16. /etc/shells
列出可以使用的s h e l l。chsh 命令允许用户在本文件指定范围内改变登录的s h e l l。提供一
台机器f t p服务的服务进程ftpd 检查用户s h e l l是否列在/etc/shells 文件中,如果不是,将不允
许该用户登录。
17. /etc/termcap
终端性能数据库。说明不同的终端用什么“转义序列”控制。写程序时不直接输出转义
序列(这样只能工作于特定品牌的终端),而是从/etc/termcap 中查找要做的工作的正确序列。
这样,多数的程序可以在多数终端上运行。
/dev文件系统
/dev 目录包括所有设备的设备文件。设备文件用特定的约定命名,这在设备列表中说明。
设备文件在安装时由系统产生,以后可以用/dev/makedev 描述。/ d e v / m a k e d e v.local 是
系统管理员为本地设备文件(或连接)写的描述文稿(即如一些非标准设备驱动不是标准
makedev 的一部分)。下面简要介绍/ d e v下一些常用文件。
1. /dev/console
系统控制台,也就是直接和系统连接的监视器。
2. /dev/hd
i d e硬盘驱动程序接口。如: / d e v / h d a指的是第一个硬盘, h a d 1则是指/ d e v / h d a的第一个
分区。如系统中有其他的硬盘,则依次为/ d e v / h d b、/ d e v / h d c、. . . . . .;如有多个分区则依次为
h d a 1、h d a 2 . . . . . .
3. /dev/sd
s c s i磁盘驱动程序接口。如有系统有s c s i硬盘,就不会访问/ d e v / h a d,而会访问/ d e v / s d a。
4. /dev/fd
软驱设备驱动程序。如: / d e v / f d 0指系统的第一个软盘,也就是通常所说的a:盘,
/ d e v / f d 1指第二个软盘,. . . . . .而/ d e v / f d 1 h 1 4 4 0则表示访问驱动器1中的4 . 5高密盘。
5. /dev/st
s c s i磁带驱动器驱动程序。
6. /dev/tty
提供虚拟控制台支持。如: / d e v / t t y 1指的是系统的第一个虚拟控制台, / d e v / t t y 2则是系统
的第二个虚拟控制台。
7. /dev/pty
提供远程登陆伪终端支持。在进行te l n e t登录时就要用到/ d e v / p t y设备。
8. /dev/ttys
计算机串行接口,对于d o s来说就是“ c o m 1”口。
9. /dev/cua
计算机串行接口,与调制解调器一起使用的设备。
10. /dev/null
“黑洞”,所有写入该设备的信息都将消失。例如:当想要将屏幕上的输出信息隐藏起来
时,只要将输出信息输入到/ d e v / n u l l中即可。
/usr文件系统
/usr 是个很重要的目录,通常这一文件系统很大,因为所有程序安装在这里。/usr 里的
所有文件一般来自l i n u x发行版( d i s t r i b u t i o n );本地安装的程序和其他东西在/usr/local 下,因为这样可以在升级新版系统或新发行版时无须重新安装全部程序。/usr 目录下的许多内容是
可选的,但这些功能会使用户使用系统更加有效。/ u s r可容纳许多大型的软件包和它们的配置
文件。下面列出一些重要的目录(一些不太重要的目录被省略了)。
1. /usr/x11r6
包含x wi n d o w系统的所有可执行程序、配置文件和支持文件。为简化x的开发和安装,
x的文件没有集成到系统中。x wi n d o w系统是一个功能强大的图形环境,提供了大量的图形
工具程序。用户如果对microsoft wi n d o w s或m a c h i n t o s h比较熟悉的话,就不会对x wi n d o w系统感到束手无策了。
2. /usr/x386
类似/ u s r / x 11r6 ,但是是专门给x 11 release 5的。
3. /usr/bin
集中了几乎所有用户命令,是系统的软件库。另有些命令在/bin 或/usr/local/bin 中。
4. /usr/sbin
包括了根文件系统不必要的系统管理命令,例如多数服务程序。
5. /usr/man、/ u s r / i n f o、/ u s r / d o c
这些目录包含所有手册页、g n u信息文档和各种其他文档文件。每个联机手册的“节”
都有两个子目录。例如: / u s r / m a n / m a n 1中包含联机手册第一节的源码(没有格式化的原始文
件),/ u s r / m a n / c a t 1包含第一节已格式化的内容。l联机手册分为以下九节:内部命令、系统调
用、库函数、设备、文件格式、游戏、宏软件包、系统管理和核心程序。
6. /usr/include
包含了c语言的头文件,这些文件多以. h结尾,用来描述c语言程序中用到的数据结构、
子过程和常量。为了保持一致性,这实际上应该放在/usr/lib 下,但习惯上一直沿用了这个名
字。
7. /usr/lib
包含了程序或子系统的不变的数据文件,包括一些s i t e - w i d e配置文件。名字l i b来源于库
(library); 编程的原始库也存在/usr/lib 里。当编译程序时,程序便会和其中的库进行连接。也
有许多程序把配置文件存入其中。
8. /usr/local
本地安装的软件和其他文件放在这里。这与/ u s r很相似。用户可能会在这发现一些比较大
的软件包,如t e x、e m a c s等。
/var文件系统
/var 包含系统一般运行时要改变的数据。通常这些数据所在的目录的大小是要经常变化
或扩充的。原来/ v a r目录中有些内容是在/ u s r中的,但为了保持/ u s r目录的相对稳定,就把那
些需要经常改变的目录放到/ v a r中了。每个系统是特定的,即不通过网络与其他计算机共享。
下面列出一些重要的目录(一些不太重要的目录省略了)。
1. /var/catman
包括了格式化过的帮助( m a n )页。帮助页的源文件一般存在/ u s r / m a n / m a n中;有些m a n页
可能有预格式化的版本,存在/ u s r / m a n / c a t中。而其他的m a n页在第一次看时都需要格式化,
格式化完的版本存在/var/man 中,这样其他人再看相同的页时就无须等待格式化了。
(/var/catman 经常被清除,就像清除临时目录一样。)
2. /var/lib
存放系统正常运行时要改变的文件。
3. /var/local
存放/usr/local 中安装的程序的可变数据(即系统管理员安装的程序)。注意,如果必要,
即使本地安装的程序也会使用其他/var 目录,例如/var/lock 。
4. /var/lock
锁定文件。许多程序遵循在/var/lock 中产生一个锁定文件的约定,以用来支持他们正在
使用某个特定的设备或文件。其他程序注意到这个锁定文件时,就不会再使用这个设备或文
件。
5. /var/log
各种程序的日志( l o g )文件,尤其是login (/var/log/wtmp log纪录所有到系统的登录和注
销) 和syslog (/var/log/messages 纪录存储所有核心和系统程序信息)。/var/log 里的文件经常不
确定地增长,应该定期清除。
6. /var/run
保存在下一次系统引导前有效的关于系统的信息文件。例如, /var/run/utmp 包含当前登
录的用户的信息。
7. /var/spool
放置“假脱机( s p o o l )”程序的目录,如m a i l、n e w s、打印队列和其他队列工作的目录。每
个不同的s p o o l在/var/spool 下有自己的子目录,例如,用户的邮箱就存放在/var/spool/mail 中。
8. /var/tmp
比/tmp 允许更大的或需要存在较长时间的临时文件。
注意系统管理员可能不允许/var/tmp 有很旧的文件。
/proc文件系统
/proc 文件系统是一个伪的文件系统,就是说它是一个实际上不存在的目录,因而这是一
个非常特殊的目录。它并不存在于某个磁盘上,而是由核心在内存中产生。这个目录用于提
供关于系统的信息。下面说明一些最重要的文件和目录(/proc 文件系统在proc man页中有更详
细的说明)。
1. /proc/x
关于进程x的信息目录,这一x是这一进程的标识号。每个进程在/proc 下有一个名为自
己进程号的目录。
2. /proc/cpuinfo
存放处理器( c p u )的信息,如c p u的类型、制造商、型号和性能等。
3. /proc/devices
当前运行的核心配置的设备驱动的列表。
4. /proc/dma
显示当前使用的d m a通道。
5. /proc/filesystems
核心配置的文件系统信息。
6. /proc/interrupts
显示被占用的中断信息和占用者的信息,以及被占用的数量。
7. /proc/ioports
当前使用的i / o端口。
8. /proc/kcore
系统物理内存映像。与物理内存大小完全一样,然而实际上没有占用这么多内存;它仅
仅是在程序访问它时才被创建。(注意:除非你把它拷贝到什么地方,否则/proc 下没有任何
东西占用任何磁盘空间。)
9. /proc/kmsg
核心输出的消息。也会被送到s y s l o g。
10. /proc/ksyms
核心符号表。
11. /proc/loadavg
系统“平均负载”; 3个没有意义的指示器指出系统当前的工作量。
12. /proc/meminfo
各种存储器使用信息,包括物理内存和交换分区( s w a p )。
13. /proc/modules
存放当前加载了哪些核心模块信息。
14. /proc/net
网络协议状态信息。
15. /proc/self
存放到查看/proc 的程序的进程目录的符号连接。当2个进程查看/proc 时,这将会是不同
的连接。这主要便于程序得到它自己的进程目录。
16. /proc/stat
系统的不同状态,例如,系统启动后页面发生错误的次数。
17. /proc/uptime
系统启动的时间长度。
18. /proc/version
核心版本。 
Linux内核子目录结构:
a. arch:与体系结构相关的代码,对于每个架构的CPU,arch目录下有一个对应的子目录,比如arch/arm、arch/i386等。
b. Kernel:内核管理的核心代码,与处理器相关的代码位于arch/*/kernel/目录下。
c. drivers:所有的设备驱动程序,里面每一个子目录对应一类驱动程序。
d. fs:Linux支持的文件系统的代码,每个子目录对应一种文件系统。(如果要自行添加文件系统驱动程序,一般都放置在本目录下)
e. include:内核头文件,有基本头文件(include/linux/)、各种驱动或功能部件的头文件(include/media/、include/mtd/、include/net/)、各种体系相关的头文件(include/asm-arm/、include/asm-i386/等)。
f. init:内核的初始化代码(不是系统的启动代码),其中的main.c文件中的strat_kernel函数是内核引导后运行的第一个函数。
g. lib:内核用到的一些库函数代码,与处理器相关的库函数代码位于arch/*/lib/目录下。
h. usr:用来制作一个
i. crypto:常用加密和散列算法,还有一些压缩和CRC校验算法。
j. block:块设备的通用函数。
k. mm:内存管理代码,与处理器相关的内存管理代码位于arch/*/mm/目录下。
l. net:网络支持代码,每个子目录对应于网络的一个方面。
m. security:安全、密钥相关的代码。
n. sound:音频设备的驱动程序。
o. ipc:进程间通信的代码。
p. Documentation:内核文档。
r. scripts:用于配置、编译内核的脚本文件。
<think>我们被要求解释Linux各个文件夹的主要作用。根据提供的引用,我们可以整理出一个详细的目录结构说明。注意,引用[1]和[2]内容相似,引用[3]和[4]提供了额外信息。我们将综合这些引用并按照标准Linux目录结构进行说明。 标准Linux目录结构(Filesystem Hierarchy Standard, FHS)定义了目录的用途。以下是最常见的顶级目录及其作用: 1. **/bin**:存放系统启动和运行时必需的二进制可执行命令(如`ls`, `cp`, `mkdir`等),这些命令所有用户都可以使用。这是基础系统所必需的命令。[^1][^2][^4] 2. **/boot**:存放启动Linux系统所必需的文件,包括内核文件(vmlinuz)、初始内存磁盘(initramfs)以及引导加载程序(如GRUB)的配置文件。[^3] 3. **/dev**:包含设备特殊文件,这些文件代表系统中的硬件设备(如硬盘、终端、鼠标等)。例如,`/dev/sda`代表第一块硬盘。[^1] 4. **/etc**:存放系统的全局配置文件(例如网络配置、用户账户配置、服务配置等)。子目录`/etc/rc.d`包含启动脚本(在基于System V init的系统中)。[^1] 5. **/home**:普通用户的主目录基点。每个用户在此目录下有一个以其用户名命名的子目录(如用户`user`的主目录是`/home/user`),用户对自己的主目录有完全控制权。[^1] 6. **/lib**:存放系统程序运行所需的共享库(类似于Windows的.dll文件)和内核模块。这些库是`/bin`和`/sbin`中的二进制文件所依赖的。[^1] 7. **/lost+found**:当文件系统发生错误(如系统崩溃)时,一些“无家可归”的文件片段可能会被恢复到这里。通常每个文件系统(如分区)都会有一个这样的目录。[^1] 8. **/mnt**:临时挂载点,用于手动挂载外部文件系统(如U盘、移动硬盘)的目录。通常由系统管理员使用。[^2] 9. **/opt**:用于安装可选(第三方)应用程序。每个应用程序通常安装在其自己的子目录下,例如`/opt/firefox`。[^2] 10. **/proc**:一个虚拟文件系统,它映射内存和内核数据结构,提供系统运行时的信息(如进程信息、硬件信息)。目录中的文件不是真正的磁盘文件,而是实时数据。[^2] 11. **/root**:系统管理员(root)的主目录。普通用户没有权限访问。[^2] 12. **/sbin**:存放系统管理命令(如`fdisk`、`ifconfig`、`reboot`),这些命令通常需要root权限才能执行。[^4] 13. **/tmp**:存放临时文件,所有用户都可以读写。系统重启时,该目录下的文件通常会被清除。 14. **/usr**:存放用户安装的应用程序和文件,是系统中占用空间最大的目录之一。包含多个子目录: - `/usr/bin`:大部分用户命令(非系统必需的命令)。 - `/usr/sbin`:系统管理命令(非系统必需的管理命令)。 - `/usr/lib`:应用程序的共享库。 - `/usr/include`:C/C++等程序的头文件。 - `/usr/share`:共享数据(如文档、字体、图标等)。 - `/usr/src`:源代码(如内核源代码通常放在`/usr/src/linux`)。 - `/usr/local`:本地安装的软件(由系统管理员安装),其结构类似`/usr`(有bin、sbin、lib等子目录)。 15. **/var**:存放经常变化的文件,如日志文件(`/var/log`)、邮件队列、打印队列、数据库文件等。[^2] 16. **/srv**:存放服务数据(如网站文件、FTP数据等),但这不是强制的。 17. **/run**:存放自系统启动以来描述系统信息的文件(如进程ID文件、锁文件等)。这是一个临时文件系统(tmpfs),重启后丢失。 注意:不同的Linux发行版可能会有细微差异,但以上目录结构是遵循FHS标准的。 根据引用[3],在系统启动过程中,内核首先被加载(此时还没有虚拟文件系统),然后内核创建虚拟文件系统,并从`/sbin`和`/etc`等目录加载启动所需的程序和服务。 总结:这些目录按照功能划分,使得系统文件组织有序,便于管理和维护。 §§相关问题§§ 1. Linux中`/usr`目录和`/usr/local`目录的区别是什么? 2. 如何查看Linux系统各个目录的磁盘使用情况? 3. 为什么Linux需要将不同类型的文件放在不同的目录下? 4. 如何正确配置Linux的环境变量以包含不同目录下的可执行文件? </think> ### Linux 文件系统目录结构详解 以下是 Linux 系统核心目录的作用说明,遵循 **FHS(文件系统层次结构标准)**: #### 核心目录 1. **`/bin`** - **二进制可执行命令**(基础系统必需) - 所有用户可用(如 `ls`, `cp`, `mkdir`) - 系统启动和修复的关键命令[^1] 2. **`/boot`** - **系统启动文件** - 内核文件 (`vmlinuz`)、引导加载程序(如 GRUB) - 示例:`/boot/vmlinuz-5.15.0`(内核文件) 3. **`/dev`** - **设备特殊文件** - 硬件设备接口(如 `/dev/sda` 硬盘,`/dev/tty` 终端) - 虚拟设备:`/dev/null`(黑洞设备) 4. **`/etc`** - **系统配置文件** - 全局配置(如网络配置、用户账户) - 子目录 `/etc/rc.d`:启动脚本(System V 风格)[^3] 5. **`/home`** - **用户主目录** - 普通用户私有空间(如用户 `alice` 目录为 `/home/alice`) - 路径简写:`~alice`[^1] 6. **`/lib`** - **共享库文件** - 类似 Windows 的 `.dll` 文件 - `/bin` 和 `/sbin` 命令的依赖库 #### 系统管理目录 7. **`/sbin`** - **系统管理命令** - 需 root 权限执行(如 `fdisk`, `ifconfig`)[^2] 8. **`/root`** - **root 用户主目录** - 系统管理员专属目录[^1] 9. **`/tmp`** - **临时文件存储** - 所有用户可读写(重启后自动清理)[^2] #### 特殊用途目录 10. **`/mnt`** - **临时挂载点** - 手动挂载外部设备(如 U 盘、网络存储)[^1] 11. **`/proc`** - **虚拟文件系统** - 实时系统信息映射(如 `/proc/cpuinfo` 查看 CPU 信息) - 非磁盘文件,直接读取内存数据[^3] 12. **`/lost+found`** - **文件恢复区** - 系统崩溃后恢复的碎片文件 #### 扩展目录 13. **`/opt`** - **可选软件包** - 第三方软件独立安装位置(如 `/opt/firefox`) 14. **`/usr`** - **用户程序资源** - 子目录: - `/usr/bin`:用户程序(非系统必需) - `/usr/sbin`:管理员程序(非系统必需) - `/usr/lib`:程序库文件 - `/usr/src`:源代码(如内核源码)[^2] 15. **`/var`** - **动态数据** - 日志文件 (`/var/log`)、缓存 (`/var/cache`)、邮件队列 ### 目录结构关系示例 ```bash / ├── bin # 核心命令 ├── etc # 配置文件 ├── home # 用户目录 │ └── user ├── usr # 应用程序 │ ├── bin │ └── lib └── var # 可变数据 └── log ``` > **关键设计原则**: > - **分层管理**:系统文件(`/bin`, `/sbin`)与用户文件(`/home`, `/usr`)分离 > - **最小权限**:关键目录(如 `/root`)限制访问 > - **动态/静态分离**:静态程序(`/usr`)与动态数据(`/var`)分开存储
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值