Linux运维三:系统目录结构
Linux系统目录结构官方参考:http://www.pathname.com/fhs/
1:Linux树状目录结构图
下面目录中标红的是必须要掌握的!
2:根目录
目录 |
描述 |
/ |
第一层次结构的根、整个文件系统层次结构的根目录。 |
/bin/ |
需要在单用户模式可用的必要命令(可执行文件);面向所有用户,例如:cat、ls、cp,和/usr/bin类似。 |
/boot/ |
引导程序文件,例如:kernel、initrd;时常是一个单独的分区 |
/dev/ |
设备目录。必要设备, 例如:, /dev/null. |
/etc/ |
系统配置及服务配置文件,启动命令的目录。 特定主机,系统范围内的配置文件。 |
/etc/opt/ |
/opt/的配置文件 |
/etc/x11/ |
X_Window系统(版本11)的配置文件 |
/etc/sgml/ |
SGML的配置文件 |
/etc/xml/ |
XML的配置文件 |
/home/ |
用户的家目录,包含保存的文件、个人设置等,一般为单独的分区。 |
/lib/ |
/bin/ and /sbin/中二进制文件必要的库文件。 |
/media/ |
可移除媒体(如CD-ROM)的挂载点 (在FHS-2.3中出现)。 |
/lost+found/ |
在ext3文件系统中,当系统意外崩溃或机器意外关机,会产生一些文件碎片在这里。当系统在开机启动的过程中fsck工具会检查这里,并修复已经损坏的文件系统。当系统发生问题。可能会有文件被移动到这个目录中,可能需要用手工的方式来修复,或移到文件到原来的位置上。 |
/mnt/ |
临时挂载的文件系统。比如cdrom,u盘等,直接插入光驱无法使用,要先挂载后使用 |
/opt/ |
可选应用软件包。 |
/proc/ |
显示内核及进程信息的虚拟文件系统。 虚拟文件系统,将内核与进程状态归档为文本文件(系统信息都存放这目录下)。例如:uptime、 network。在Linux中,对应Procfs格式挂载。该目录下文件只能看不能改(包括root) |
/root/ |
超级用户的家目录 |
/sbin/ |
必要的系统二进制文件,例如: init、 ip、 mount。sbin目录下的命令,普通用户都执行不了。 |
/srv/ |
站点的具体数据,由系统提供。 |
/tmp/ |
临时文件(参见 /var/tmp),在系统重启时目录中文件不会被保留。 |
/usr/ |
用户程序,及数据,帮助文件,二进制命令等的目录。 默认软件都会存于该目录下。用于存储只读用户数据的第二层次;包含绝大多数的(多)用户工具和应用程序。 |
/var/ |
变化的目录,一般是日志文件,cache的目录。 变量文件——在正常运行的系统中其内容不断变化的文件,如日志,脱机文件和临时电子邮件文件。有时是一个单独的分区。如果不单独分区,有可能会把整个分区充满。如果单独分区,给大给小都不合适。 |
根目录下的重点目录:
/dev/ 设备目录
/etc/ 系统配置及服务配置文件,启动命令的目录
/proc 显示内核及进程信息的虚拟文件系统
/tmp 临时文件目录,公共厕所,客厅
/home 普通用户家目录,大臣的家
/root 超级管理员的家目录,皇宫
/var 变化的目录,一般是日志文件,cache的目录
/usr 用户程序,及数据,帮助文件,二进制命令等的目录
/bin,/sbin,/usr/sbin 用户命令的目录
3:/etc/目录
目录 |
描述 |
/etc/rc.local |
用于存放开机自启动程序命令的文件(chkconfig常用来管理yum/rpm安装的程序的服务的开机自启动)。系统开机时会把/etc/rc.local里的内容执行一遍。 让一个程序开机自启动的两种办法: 1)chkconfig (/etc/init.d/sshd) 2)放入/etc/rc.local 一般在工作中,一台服务器上跑了些什么程序,会记录在此文件中,并且注释!方便其他运维人员快速掌握该机器上运行的程序! |
/etc/hosts |
本地域名解析文件!最好把本机的IP与本机的主机名也写入到该文件中! hosts企业里的应用: 1:开发,产品,测试等人员,用于通过正式的域名测试产品 2:服务器之间的调用可以用域名(内部的DNS),方便迁移 |
/etc/sysconfig/network |
主机名的配置文件! 该文件在启动过程中,会被/etc/init.d/network文件调用 更改主机名: 1:vi /etc/sysconfig/network 2:hostname 主机名 3:vi /etc/hosts 上面三个文件同时修改 |
/etc/resolv.conf |
DNS服务器配置!这里注意网卡里的DNS配置优先于此文件的DNS配置!面试的时候注意下这个地方,工作中如果需要配置DNS,就在网卡文件配置即可! |
/etc/fstab |
开机自动挂载系统,所有分区开机都会自动挂载。 生产场景的应用,文件参数详细解释见:http://www.cnblogs.com/ginvip/p/6351740.html |
/etc/inittab |
设定系统启动时Init进程将把系统设置成什么样的runlevel运行级别及加载相关的启动文件配置 |
/etc/exports |
设置NFS系统用的配置文件路径 |
/etc/init.d |
这个目录用来存放系统启动脚本 |
/etc/profile |
系统全局环境变量永久生效的配置文件 定义别名以及PATH变量等 用户的环境变量:~/.bash_profile , ~/.bashrc |
/etc/profile.d |
加载系统登录程序的一个目录,命令或文件独立存在! 以文件的形式存在(.sh为扩展名),但要可执行 [root@Gin ~]# cat /etc/profile.d/gin.sh 退出当前终端,再次登录,该脚本就会自动执行,屏幕上就会显示上面的内容 /etc/profile.d 登录后执行的脚本所在地 /etc/motd 登录后显示的字符串 |
/etc/issue |
记录用户登录前显示的系统版本信息 安全优化: >/etc/issue |
/etc/motd |
设置认证后的输出信息, |
/etc/mtab |
当前安装的文件系统列表.由scripts初始化,并由mount 命令自动更新.需要一个当前安装的文件系统的列表时使用,例如df 命令 |
/etc/group |
类似/etc/passwd ,但要说明的不是用户而是组. |
/etc/passwd |
用户数据库,其中的域给出了用户名、真实姓名、家目录、加密的口令和用户的其他信息. |
/etc/shadow |
在安装了影子口令软件的系统上的影子口令文件.影子口令文件将/etc/passwd 文件中的加密口令移动到/etc/shadow 中,而后者只对root可读.这使破译口令更困难. |
/etc/sudoers |
可以执行使用sudo命令的配置文件 |
/etc/syslog.conf |
系统日志参数配置 |
/etc/login.defs |
设置用户帐号限制的文件 |
/etc/securetty |
确认安全终端,即哪个终端允许root登录.一般只列出虚拟控制台,这样就不可能(至少很困难)通过modem或网络闯入系统并得到超级用户特权. |
/etc/printcap |
类似/etc/termcap ,但针对打印机.语法不同. |
/etc/shells |
列出可信任的shell.chsh 命令允许用户在本文件指定范围内改变登录shell.提供一台机器FTP服务的服务进程ftpd 检查用户shell是否列在 /etc/shells 文件中,如果不是将不允许该用户登录. |
/etc/xinet.d |
如果服务器是通过xinetd模式运行的,它的脚本要放在这个目录下。有些系统没有这个目录,比如Slackware,有些老的版本也没有。在Redhat Fedora中比较新的版本中存在。 |
/etc/opt/ |
/opt/的配置文件 |
/etc/x11/ |
X_Window系统(版本11)的配置文件 |
/etc/sgml/ |
SGML的配置文件 |
/etc/xml/ |
XML的配置文件 |
/etc/skel/ |
默认创建用户时,把该目录下的所有文件拷贝到家目录下 |
/etc/sysconfig/network-scripts/ifcfg-eth0 |
ifup eth0 启动第一块网卡 ifdown eth0 关闭第一块网卡 ip a 或 ip add 查看网卡ip 该文件的详细内容见:http://www.cnblogs.com/ginvip/p/6351740.html |
4:/usr/目录
/usr 是系统核心所在,包含了所有的共享文件。它是 unix 系统中最重要的目录之一,涵盖了二进制文件,各种文档,各种头文件,x,还有各种库文件;还有诸多程序,例如 ftp,telnet 等等。
/usr/games |
曾经包含游戏等文件,现在很少用到; |
/usr/doc |
文档。实际是 /usr/share/doc 的软链接; |
/usr/include |
各种头文件,编译文件等时需要使用; /usr/include/’package-name’ : 程序特定的头文件; |
/usr/etc/ |
一个极少用到的配置文件存放地; |
/usr/man |
man 手册,已经移至 /usr/share/man; |
/usr/src |
linux 内核的源码和说明文档等; /usr/src/linux : linux 源代码; |
/usr/bin |
非必要可执行文件 (在单用户模式中不需要);面向所有用户。 |
/usr/lib |
所有可执行文件所需要的库文件; |
/usr/sbin/ |
类似 /sbin,root 可以执行。但此目录不包含在环境变量 $PATH 中,它包含的程序类似于 chroot, useradd, in.tftpd and pppconfig; |
/usr/share/ |
它包含了各种程序间的共享文件,如字体,图标,文档等。(/usr/local 对应的目录是 /usr/loca/share); /usr/share/doc : 类似应用程序的 man 手册。它包含程序的说明文件,默认配置文件等; |
/usr/X11R6 |
x 系统的二进制文件,库文件,文档,字体等。它不等同于 /usr 的作用,只有 x 才能调用这些库文件等,其他程序不读取或者使用。因为 linux 没有原生图形界面,而且 linux 大部分情况下是 for server 的,所以图形界面没有意义;其中 X11R6 代表 version 11 release 6; /usr/X11R6/bin : x 的二进制文件,包含运行 x 的必须文件; |
/usr/local/ |
/usr 通常只包含系统发行时自带的程序,而 /usr/local 则是本地系统管理员用来自由添加程序的目录;相当于windowns下的c:\Programe files目录 |
5:/var/目录
/var 包括系统一般运行时要改变的数据.每个系统是特定的,即不通过网络与其他计算机共享.
/var/log/message |
系统日志信息,按周自动轮询(系统硬件,软件出故障都会记录。另外还有一个dmesg命令记录系统硬件故障) |
/var/spool/cron/ |
定时器配置文件目录,默认按用户命名 |
/var/log/secure |
安全日志信息。记录登陆系统存取信息的文件,不管认证成功还是认证失败都会记录(如SSH连接日志,有人扫描你的端口等) |
/var/log/wtmp |
记录登陆者信息的文件,last,who,w命令信息来源于此 |
/var/spool/clientmqueue |
当邮件服务未开启时,所有应发给系统管理员的邮件都将堆放在此 |
/var/spoo/mail/ |
邮件目录 mail -> spool/mail |
/var/tmp/ |
比/tmp 允许的大或需要存在较长时间的临时文件. (虽然系统管理员可能不允许/var/tmp 有很旧的文件.) |
/var/lib/ |
系统正常运行时要改变的文件. |
/var/local |
/usr/local 中安装的程序的可变数据(即系统管理员安装的程序).注意,如果必要,即使本地安装的程序也会使用其他/var 目录,例如/var/lock . |
/var/lock |
锁定文件.许多程序遵循在/var/lock 中产生一个锁定文件的约定,以支持他们正在使用某个特定的设备或文件.其他程序注意到这个锁定文件,将不试图使用这个设备或文件. |
/var/log/ |
各种程序的Log文件,特别是login (/var/log/wtmp log所有到系统的登录和注销) 和syslog (/var/log/messages 里存储所有核心和系统程序信息. /var/log 里的文件经常不确定地增长,应该定期清除. |
/var/run |
保存到下次引导前有效的关于系统的信息文件.例如, /var/run/utmp 包含当前登录的用户的信息. |
/var/cache/ |
应用程序缓存数据。这些数据是在本地生成的一个耗时的I/O或计算结果。应用程序必须能够再生或恢复数据。缓存的文件可以被删除而不导致数据丢失。 |
6:/proc/目录
虚拟文件系统,将内核与进程状态归档为文本文件(系统信息都存放这目录下)。
例如:uptime、 network。在Linux中,对应Procfs格式挂载。该目录下文件只能看不能改(包括root)
/proc/meminfo |
查看内存信息 |
/proc/loadavg |
还记得 top 以及 uptime 吧?没错!上头的三个平均数值就是记录在此! |
/proc/uptime |
就是用 uptime 的时候,会出现的资讯! |
/proc/cpuinto |
关于处理器的信息,如类型、厂家、型号和性能等。 |
/proc/cmdline |
加载 kernel 时所下达的相关参数!查阅此文件,可了解系统是如何启动的! |
/proc/filesystems |
目前系统已经加载的文件系统! |
/proc/interrups |
目前系统上面的 IRQ 分配状态。 |
/proc/ioports |
目前系统上面各个装置所配置的 I/O 位址。 |
/proc/kcore |
这个就是内存的大小啦!好大对吧!但是不要读他啦! |
/proc/modules |
目前我们的 Linux 已经加载的模块列表,也可以想成是驱动程序啦! |
/proc/mounts |
设备的挂载信息!与 dh -hT类似 |
/proc/swaps |
到底系统挂加载的内存在哪里?呵呵!使用掉的 partition 就记录在此啦! |
/proc/partitions |
使用 fdisk -l 会出现目前所有的 partition 吧?在这个文件当中也有纪录喔! |
/proc/pci |
在 PCI 汇流排上面,每个装置的详细情况!可用 lspci 来查阅! |
/proc/version |
核心的版本,就是用 uname -a 显示的内容啦! |
/proc/bus/* |
一些汇流排的装置,还有 U盘的装置也记录在此喔! |
7:/dev/目录
设备文件分为两种:块设备文件(b)和字符设备文件(c)
设备文件一般存放在/dev目录下,
对常见设备文件作如下说明:
/dev/hd[a-t] |
IDE设备 |
/dev/sd[a-z] |
SCSI设备 |
/dev/fd[0-7] |
标准软驱 |
/dev/md[0-31] |
软raid设备 |
/dev/loop[0-7] |
本地回环设备 |
/dev/ram[0-15] |
内存 |
/dev/null |
无限数据接收设备,相当于黑洞 |
/dev/zero |
无限零资源 |
/dev/tty[0-63] |
虚拟终端 |
/dev/ttyS[0-3] |
串口 |
/dev/lp[0-3] |
并口 |
/dev/console |
控制台 |
/dev/fb[0-31] |
framebuffer |
/dev/cdrom |
=> /dev/hdc |
/dev/modem |
=> /dev/ttyS[0-9] |
/dev/pilot |
=> /dev/ttyS[0-9] |
/dev/random |
随机数设备 |
/dev/urandom |
随机数设备 |
word文档下载地址:http://wenku.baidu.com/view/60751c313868011ca300a6c30c2259010202f319