zl程序教程

您现在的位置是:首页 >  系统

当前栏目

Linux-目录-配置文件详解程序员

2023-06-13 09:19:57 时间

命令:mount 设置挂载点

Linux-目录-配置文件详解程序员

 

/ 根 所有目录顶点
├── bin   普通用户命令,二进制命令所在的目录 which 可用来查找命令
├── boot Linux 内核及系统引导程序所需文件目录
├── cgroup
├── dev 设备目录
├── etc 系统配文件(yum,rpm)配置文件默认路径

fstab:开机自动挂载设置,实现开机要挂载的文件系统

命令:blkid 来查看uuidLinux-目录-配置文件详解程序员

 

hosts:主机名解析文件,本主机dns文件。相当于:C:/Windows/System32/drivers/etc/hosts

inittab:指定开机运行级别

issue:预登陆信息,登录前所显示的信息

motd:登录后的提示信息。类似banner

profile:Systemwide initialization file for sh shell logins(optional) 全局环境变量永久生效的配置文件

用户的环境变量是:~/.bash_profile, ~/.bash_rc

profile.d: 加载系统登录程序的一个目录,用户登录的时候可以加载的一些程序或是脚本

注意:/etc/profile.d 用户登录后执行脚本所在地; /etc/motd 登录后显示的字符串

resolve.conf:解析文件dns,此文件配置会被网卡配置文件中的dns配置覆盖,网卡配置文件位置:/etc/sysconfig/network-scripts

sysctl.conf: 内核优化配置

passwd:密码文件

networks:static information about network names

services:port names for network services

syslog.conf:configuration file for syslogd

sysconfig:

network:配置文件,可修改主机名。hostname只是临时修改,重启后失效

rc.local:用于存放开机启动程序命令文件(chkconfig 常用来管理yum/rpm安装的程序的服务的开机自启动),

开机时会把rc.local里面的内容读取一遍,在登陆之前会执行一次,一般自己写的程序启动会放在这

init.d:  此目录用于存放系统或服务器自动安装的软件的默认启动程序,如yum,rpm安装的软件。此目录为链接

Linux-目录-配置文件详解程序员

Linux-目录-配置文件详解程序员

 skel : 目录是用来存放新用户配置文件的目录,当我们添加新用户时,这个目录下的所有文件会自动被复制到新的用户的家目录下:默认情况下,/etc/skel 目录下的所有文件都是隐藏文件(以.点号开头):通过修改,添加,删除 /etc/skel目录下的文件,我们可以为新创建的用户提供统一的,标准的,初始化用户环境

Linux-目录-配置文件详解程序员

login.defs: 此文件是用来定义创建用户时需要的一些用户的配置信息,如创建用户时,是否需要家目录,UID和GID的范围.以及用户和密码的有效期等等.

/etc/default/useradd : 命令useradd 创建用户时,会参照/etc/default/useradd 的配置信息来创建用户

Linux-目录-配置文件详解程序员

 

 

 

├── home 普通用户家目录
├── lib
├── lib64
├── lost+found
├── media
├── misc
├── mnt
├── net
├── opt 
├── proc 显示内核以及进程信息的虚拟文件系统

version:版本信息

kernel:内核信息

meminfo:内存信息

loadavg:性能状况

mounts:挂载信息, df -h 类似

├── root root 家目录
├── sbin 超级用户命令目录
├── selinux
├── srv
├── sys
├── tmp 临时目录文件,公共厕所,客厅
├── usr Unix software resource 用户程序,数据,帮助文件,二进制命令等

local:这个目录一般是用来存放用户使用源码编译的软件存放目录。相当windows c:/program files

└── var 变化目录,一般是日志文件,cache目录

log:此目录存放日志信息 dmesg 命令可以查看系统故障信息

secure:记录登录系统存取信息的文件。自动轮询,例如:pop3,ssh,telnet,ftp 等都会记录在此

 

文件系统层次标准FHS的详细介绍

Filesystem Hierarchy Standard (文件系统层次标准,FHS)标准依据文件系统使用的频繁与否与是否允讲使用者随意更动, 而将目录定义成四种交互作用的形态,具体如下:

Linux-目录-配置文件详解程序员

可分享的:可以分享给其他系统挂载使用的目录,所以包括执行文件与用户的邮件等数据, 是能够分享给网络上其他主机挂载用的目录; 不可分享的:自己机器上面运作的装置档案或者是与程序有关的 socket 档案等, 由于仅与自身机器有关,所以当然就不适合分享给其他主机了。 不变的:有些数据是不会经常变动的,跟随着 distribution 而不变动。 例如函式库、文件说明文件、系统管理员所管理的主机服务配置文件等等; 可变动的:经常改变的数据,例如登录文件、一般用户可自行收受的新闻组等。

事实上,FHS针对目录树架构仅定义出三层目录下应该放置哪些数据,分别是下面三个目录:

/(根目录):与开机系统有关; /usr(unix software resource):与软件安装执行有关; /var(variable):与系统运作过程有关。

下面分别对上述三层目录进行详细的阐述。

(1) /(根目录)

根目录是整个系统最重要的一个目录,因为不但所有的目录都是由根目录衍生出来的,同时根目录也与开机/还原/系统修复等动作有关。由于系统开机时需要特定的开机软件、核心档案、开机所需程序、函式库等等档案数据,若系统出现错误时,根目录也必须要包含有能够修复文件系统的程序才行。因为根目录是如此重要,所以在FHS的要求方面,希望根目录不要放在非常大的分割槽中,因为越大的分割槽会放入越多的数据,如此一来根目录所在分割槽就可能会有较多发生错误的机会。

因此通常情况下,根目录所在分割槽应该越小越好,且应用程序所安装的软件最好不要与根目录放在同一个分割槽中,保持根目录越小越好。如此不但性能较佳,同时根目录所在的文件系统也较不容易放生错误。下表为FHS所定义的根目录下应该要有的次目录的介绍:

Linux-目录-配置文件详解程序员Linux-目录-配置文件详解程序员Linux-目录-配置文件详解程序员

除此之外,Linux下还有几个其他的目录也需要了解一下,如下表:

Linux-目录-配置文件详解程序员 Linux-目录-配置文件详解程序员

在Linux中,因为根目录与开机有关,开机过程中仅有根目录会被挂载,其他分割槽则是在开机完成之后才会持续的进行挂载行为。因此,根目录下与开机过程有关的目录就不能够与根目录放到不同的分割槽中。下面这五个目录则是与开机密不可分而不能与根目录分开的目录。

/etc:配置文件 /bin:重要执行档。与一般用户及单人模式下操作有关的指令。 /dev:装置和接口配置相关的档案 /lib:执行档所需要的函式库与核心所需的模块 /sbin:与系统管理员操作有关的指令

(2) /usr

根据FHS的定义,/usr里面放置的数据属于可分享的但不可变动的数据。类似于Windows系统的C:/Windows与C:/Program Files这两个目录的综合体。建议所有软件开发者将他们饿数据合理的分别放置在这个目录下的次目录中,而不是自行建立该软件自己独立的目录。

Linux-目录-配置文件详解程序员Linux-目录-配置文件详解程序员

(3) /var

/var目录主要针对常态性变动的档案,包括快取(cache)、登陆档(log file)、以及某些软件运作所产生的档案,包括程序档案(lock file, run file),或者例如MySQL数据库的档案等等。常见的次目录有:

Linux-目录-配置文件详解程序员

综上即为FHS标准,接下来,我们将整个目录树以图标的方法来显示,并且将较为重要的档案数据列出来。

Linux-目录-配置文件详解程序员

 

 

1、树状目录结构图

 

Linux-目录-配置文件详解程序员

 

 

2、/目录

 


在ext3文件系统中,当系统意外崩溃或机器意外关机,会产生一些文件碎片在这里。当系统在开机启动的过程中fsck工具会检查这里,并修复已经损坏的文件系统。当系统发生问题。可能会有文件被移动到这个目录中,可能需要用手工的方式来修复,或移到文件到原来的位置上。


必要的系统二进制文件,例如: init、 ip、 mount。sbin目录下的命令,普通用户都执行不了。


默认软件都会存于该目录下。用于存储只读用户数据的第二层次;包含绝大多数的(多)用户工具和应用程序。


变量文件——在正常运行的系统中其内容不断变化的文件,如日志,脱机文件和临时电子邮件文件。有时是一个单独的分区。如果不单独分区,有可能会把整个分区充满。如果单独分区,给大给小都不合适。


当前安装的文件系统列表.由scripts初始化,并由mount 命令自动更新.需要一个当前安装的文件系统的列表时使用,例如df 命令


在安装了影子口令软件的系统上的影子口令文件.影子口令文件将/etc/passwd 文件中的加密口令移动到/etc/shadow 中,而后者只对root可读.这使破译口令更困难.


确认安全终端,即哪个终端允许root登录.一般只列出虚拟控制台,这样就不可能(至少很困难)通过modem或网络闯入系统并得到超级用户特权.


列出可信任的shell.chsh 命令允许用户在本文件指定范围内改变登录shell.提供一台机器FTP服务的服务进程ftpd 检查用户shell是否列在 /etc/shells 文件中,如果不是将不允许该用户登录.


如果服务器是通过xinetd模式运行的,它的脚本要放在这个目录下。有些系统没有这个目录,比如Slackware,有些老的版本也没有。在Redhat Fedora中比较新的版本中存在。


 

4、/usr/目录

默认软件都会存于该目录下。用于存储只读用户数据的第二层次;包含绝大多数的用户工具和应用程序。


本地数据的第三层次,具体到本台主机。通常而言有进一步的子目录,例如:bin/、lib/、share/.这是提供给一般用户的/usr目录,在这里安装一般的应用软件;


 

5、/var/目录

/var 包括系统一般运行时要改变的数据.每个系统是特定的,即不通过网络与其他计算机共享.

 


比/tmp 允许的大或需要存在较长时间的临时文件. (虽然系统管理员可能不允许/var/tmp 有很旧的文件.)


/usr/local 中安装的程序的可变数据(即系统管理员安装的程序).注意,如果必要,即使本地安装的程序也会使用其他/var 目录,例如/var/lock .  


锁定文件.许多程序遵循在/var/lock 中产生一个锁定文件的约定,以支持他们正在使用某个特定的设备或文件.其他程序注意到这个锁定文件,将不试图使用这个设备或文件.


各种程序的Log文件,特别是login   (/var/log/wtmp log所有到系统的登录和注销) 和syslog (/var/log/messages 里存储所有核心和系统程序信息. /var/log 里的文件经常不确定地增长,应该定期清除.  


保存到下次引导前有效的关于系统的信息文件.例如, /var/run/utmp 包含当前登录的用户的信息.


应用程序缓存数据。这些数据是在本地生成的一个耗时的I/O或计算结果。应用程序必须能够再生或恢复数据。缓存的文件可以被删除而不导致数据丢失。


还记得 top 以及 uptime 吧?没错!上头的三个平均数值就是记录在此!


使用 fdisk -l 会出现目前所有的 partition 吧?在这个文件当中也有纪录喔!


 

7、/dev/目录

设备文件分为两种:块设备文件(b)和字符设备文件(c)
设备文件一般存放在/dev目录下,

对常见设备文件作如下说明: