这篇文章的内容主要来自于网络进行整理。
一 系统目录结构总结
1 /bin:bin是Binary的缩写,该目录下存放的是最常用的命令,特殊在放置的是在单用户维护模式下还能够被操做的命令,。被root与一般用户可以使用的命令有cat ,chmod,chown,date,mv,mkdir,cp,bash。
2 /boot:该目录下存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件。linux kernel常用的文件名为vmlinuz. 如果使用gurb引导程序则会有/boot/grub 此目录
3 /dev:dev是Device(设备)的缩写。该目录下存放的是Linux的外部设备。在Linux中,访问设备的方式和访问文件的方式是相同的。此目录下有如下重要的文件:/dev/null ,/dev/zero. /dev/tty./dev/lp*/dev/hd*,/dev/sd*
4 /etc:该目录下存放的是所有系统管理所需要的配置文件和子目录。/etc目录下是系统的配置文件,如果更改了该目录下的某个文件可能会导致系统无法正常启动。
/etc/rc /etc/rc.d
/etc/rc*.d
启动、或改变运行级时运行的scripts或scripts的目录.
/etc/hosts
本地域名解析文件
/etc/sysconfig/network-scripts/ifcfg-ens33
IP、掩码、网关、主机名配置 (centos7的默认为ens33)
/etc/resolv.conf
DNS服务器配置
/etc/fstab
开机自动挂载系统,所有分区开机都会自动挂载
/etc/inittab
设定系统启动时Init进程将把系统设置成什么样的runlevel及加载相关的启动文件配置
/etc/exports
设置NFS系统用的配置文件路径
/etc/init.d
这个目录来存放系统启动脚本
/etc/profile,/etc/csh.login, /etc/csh.cshrc
全局系统环境配置变量
/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/xinetd.d
如果服务器是通过xinetd模式运行的,它的脚本要放在这个目录下。有些系统没有这个目录,比如Slackware,有些老的版本也没有。在Redhat Fedora中比较新的版本中存在。
/etc/opt/
/opt/的配置文件
/etc/X11/
X_Window系统(版本11)的配置文件
/etc/sgml/
SGML的配置文件
/etc/xml/
XML的配置文件
/etc/skel/
默认创建用户时,把该目录拷贝到家目录下
5 /home:这是用户的主目录。在Linux中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的。
6 /lib和/lib64:这两个目录下存放的是系统最基本的动态连接共享库,其作用类似于Windows里的DLL文件,几乎所有的应用程序都需要用到这些共享库。其中/lib64为64位的软件包的库文件所在目录。
7 /media:系统会自动识别一些设备(如U盘、光驱等),当识别后,Linux会把识别的设备挂载到该目录下。
8 /mnt:系统提供该目录是为了让用户临时挂载别的文件系统。我们可以将光驱挂载到/mnt/上,然后进入该目录查看光驱里的内容。
9 /opt:这是给主机额外安装软件所设置的目录,该目录默认为空。比如你要安装一个ORACLE数据库,可以放到该目录下。
10 /proc:该目录是一个虚拟的目录,是系统内存的映射,我们可以通过直接访问来获取系统信息。该目录的内容在内存里,我们可以直接修改里面的某些文件。比如可以通过下面的命令来屏蔽主机的ping命令,使其他人无法ping你的机器。后续,在日常工作中,你会经常用到类似的用法。
# echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all
11 /root:该目录是系统管理员的用户主目录。
12 /run:这个目录其实和/var/run是同一个目录,这里面存放的是一些服务的pid,一个服务启动完后,是有一个pid文件的。至于为什么说是同一个目录,Linux是如何做到的,后续我们再介绍。(重启后此文件会消失)
13 /sbin:s就是Super User的意思,该目录存放的是系统管理员使用的系统管理程序只有root可以使用的命令。常见的命令有:fdisk,fsck,ifconfig,init,mkfs.
14 /srv:该目录存放的是一些服务启动之后需要提取的数据。(空的文件)
15 /sys:该目录存放的是与硬件驱动程序相关的信息。
16 /tmp:该目录是用来存放一些临时文件的。
17 /usr:这是一个非常重要的目录,类似于Windows下的Program Files目录,用户的很多应用程序和文件都存放在该目录下。后面的章节中,我们会多次用到这个目录。(usr 是UNIX Software Resource 操作系统软件资源)
目录 | 描述 |
/usr/X11R6 | 存放X-Windows的目录; |
/usr/games | 存放着XteamLinux自带的小游戏; |
/usr/doc | Linux技术文档; |
/usr/include | 用来存放Linux下开发和编译应用程序所需要的头文件; |
/usr/lib | 存放一些常用的动态链接共享库和静态档案库; |
/usr/man | 帮助文档所在的目录; |
/usr/bin/ | 该目录存放的是系统用户使用的应用程序,注意是否与开机程序有关。 |
/usr/lib/ | /usr/bin/和/usr/sbin/中二进制文件的库。 |
/usr/sbin/ | 非必要的系统二进制文件,例如:大量网络服务的守护进程。该目录存放的是超级用户使用的比较高级的管理程序和系统守护程序。 |
/usr/share/ | 体系结构无关(共享)数据。 |
/usr/src/ | 源代码,例如:内核源代码及其头文件。该目录是内核源代码默认的放置目录。 |
/usr/X11R6/ | X Window系统版本 11, Release 6. |
/usr/local/ | 本地数据的第三层次,具体到本台主机。通常而言有进一步的子目录,例如:bin/、lib/、share/.这是提供给一般用户的/usr目录,在这里安装一般的应用软件; |
18 /var:该目录存放的是在不断扩充且经常被修改的目录,包括各种日志文件或者pid文件,刚刚提到的/var/run就是
/var/log/message | 日志信息,按周自动轮询 |
/var/spool/cron/root | 定时器配置文件目录,默认按用户命名 |
/var/log/secure | 记录登陆系统存取信息的文件,不管认证成功还是认证失败都会记录 |
/var/log/wtmp | 记录登陆者信息的文件,last,who,w命令信息来源于此 |
/var/spool/clientmqueue/ | 当邮件服务未开启时,所有应发给系统管理员的邮件都将堆放在此 |
/var/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或计算结果。应用程序必须能够再生或恢复数据。缓存的文件可以被删除而不导致数据丢失。 |
注释:
-
/bin、/sbin、/usr/bin和/usr/sbin目录是系统预设的执行文件的放置目录,其中/bin和/usr/bin目录下是供系统用户使用的指令(除root外的通用账户),而/sbin和/usr/sbin目录下则是供root使用的指令。比如ls指令就存放在/bin/目录下。
2 /var也是一个非常重要的目录,系统上运行各个程序时所产生的日志都被记录在该目录下(即/var/log目录中),另外mail指令的预设也放置在这里。 `
3.ls /root/.ssh/authorized_keys 后面的这个是由ls /etc/ssh/sshd_config的配置文件规定的。
4 .tree 以树形显示目录下面有哪些子目录或文件的([root@chy ~]# yum install -y tree)
[root@chy ~]# tree -L 2 / 以二层的形式显示目录
5. 怎么样看一个命令依赖的哪些库文件
[root@chy ~]# ldd /bin/ls
本文转自我不是瘦子51CTO博客,原文链接:http://blog.51cto.com/chy940405/1983289,如需转载请自行联系原作者