• Linux-目录-配置文件


    命令:mount 设置挂载点

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

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

    命令:blkid 来查看uuid

    hosts:主机名解析文件,本主机dns文件。相当于:C:WindowsSystem32driversetchosts

    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安装的软件。此目录为链接

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

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

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

     

    ├── 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)标准依据文件系统使用的频繁与否与是否允讲使用者随意更动, 而将目录定义成四种交互作用的形态,具体如下:

      

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

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

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

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

    (1) /(根目录)

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

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

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

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

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

    (2) /usr

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

    (3) /var

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

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


    1、树状目录结构图

    2、/目录

    目录

    描述

    /

    第一层次结构的根、整个文件系统层次结构的根目录

    /bin/

    需要在单用户模式可用的必要命令(可执行文件);面向所有用户,例如:catlscp,和/usr/bin类似。

    /boot/

    引导程序文件,例如:kernelinitrd;时常是一个单独的分区[6]

    /dev/

    必要设备, 例如:, /dev/null.

    /etc/

    特定主机,系统范围内的配置文件

    关于这个名称目前有争议。在贝尔实验室关于UNIX实现文档的早期版本中,/etc 被称为/etcetra 目录[7]这是由于过去此目录中存放所有不属于别处的所有东西(然而,FHS限制/etc存放静态配置文件,不能包含二进制文件)。[8]自从早期文档出版以来,目录名称已被以各种方式重新称呼。最近的解释包括反向缩略语如:"可编辑的文本配置"(英文 "Editable Text Configuration")或"扩展工具箱"(英文 "Extended Tool Chest")。[9]

    /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/

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

    3/etc/目录

    特定主机系统范围内的配置文件

    目录

    描述

    /etc/rc /etc/rc.d

    /etc/rc*.d

    启动、或改变运行级时运行的scripts或scripts的目录.

    /etc/hosts

    本地域名解析文件

    /etc/sysconfig/network

    IP、掩码、网关、主机名配置

    /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/

    默认创建用户时,把该目录拷贝到家目录下

    4/usr/目录

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

    目录

    描述

    /usr/X11R6

    存放X-Windows的目录;

    /usr/games

    存放着XteamLinux自带的小游戏;

    /usr/doc

    Linux技术文档;

    /usr/include

    用来存放Linux下开发和编译应用程序所需要的头文件;

    /usr/lib

    存放一些常用的动态链接共享库和静态档案库;

    /usr/man

    帮助文档所在的目录;

    /usr/src

    Linux开放的源代码,就存在这个目录,爱好者们别放过哦;

    /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目录,在这里安装一般的应用软件;

    5/var/目录

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

    目录

    描述

    /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或计算结果。应用程序必须能够再生或恢复数据。缓存的文件可以被删除而不导致数据丢失。

    6/proc/目录

    虚拟文件系统,将内核进程状态归档为文本文件(系统信息都存放这目录下)。

    例如:uptime、 network。在Linux中,对应Procfs格式挂载。该目录下文件只能看不能改(包括root)

    目录

    描述

    /proc/meminfo

    查看内存信息

    /proc/loadavg

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

    /proc/uptime

    就是用 uptime 的时候,会出现的资讯啦!

    /proc/cpuinfo

    关于处理器的信息,如类型、厂家、型号和性能等。

    /proc/cmdline

    加载 kernel 时所下达的相关参数!查阅此文件,可了解系统是如何启动的!

    /proc/filesystems  

    目前系统已经加载的文件系统罗!

    /proc/interrupts

    目前系统上面的 IRQ 分配状态。

    /proc/ioports

    目前系统上面各个装置所配置的 I/O 位址。

    /proc/kcore

    这个就是内存的大小啦!好大对吧!但是不要读他啦!

    /proc/modules

    目前我们的 Linux 已经加载的模块列表,也可以想成是驱动程序啦!

    /proc/mounts

    系统已经挂载的数据,就是用 mount 这个命令呼叫出来的数据啦!

    /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

    随机数设备

    -------------------- 阑心而慧智,心静而致远. --------------------
  • 相关阅读:
    如何为新的应用获取更高的关键字排名
    AppStore审核不通过?看看问题出在哪儿
    django 学习-11 Django模型数据模板呈现
    django 学习-10 Django多对多关系模型
    Django学习--9 Admin
    Django学习--9 多对一关系模型
    django 学习-7 模型数据操作
    django 学习-6 定义模型--数据库的使用
    django 学习-5 模板使用流程
    django 学习-4 模板标签
  • 原文地址:https://www.cnblogs.com/mirrorlake/p/7350263.html
Copyright © 2020-2023  润新知