2.1 目录结构图

linux目录结构详细介绍_笔记

2.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 mountsbin目录下的命令,普通用户都执行不了。

/srv/

站点的具体数据,由系统提供。

/tmp/

临时文件(参见 /var/tmp)在系统重启时目录中文件不会被保留。

/usr/

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

/var/

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

2.3 /etc目录

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

目录

描述

/etc/rc /etc/rc.d

/etc/rc*.d

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

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

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

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

 

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

2.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盘的装置也记录在此喔!

 

 

 

2.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

随机数设备

PS:红色字体为比较重要的目录

2.8 /etc/hosts

/etc/hosts:局域网  主机名和IP解析,相当于DNS工具(手动维护的)

主机名要规范

172.38.18.23     reltime-search.config-vip.taobao.com

hosts企业里的作用:

1、开发,产品,测试等人员,用于通过正式的域名测试产品;

2、服务器之间的调用可以用域名(内部的DNS),方便迁移。

[root@localhost ~]# cat /etc/sysconfig/network  网关、主机名的配置文件

NETWORKING=yes

HOSTNAME=localhost

/etc/resolv.conf  linux客户端DNS 上网的DNS

2.9 /etc/fstab

fstab - static information about the filesystems 有关文件系统的静态信息

设置文件系统挂载信息的文件,是的开机能自动挂载磁盘分区

 

[root@localhost ~]# cat /etc/fstab

# /etc/fstab

# Created by anaconda on Sat May 20 16:49:42 2017

#

# Accessible filesystems, by reference, are maintained under '/dev/disk'

# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info

#

UUID=9516b54b-b75c-4901-84fa-0a61387e6be6 /                       ext4    defaults        1 1

UUID=b57c60f1-92de-490e-9faf-d1c7fcaf3306 /boot                   ext4    defaults        1 2

UUID=23e00a57-cc3d-457f-9592-c712345310a6 swap                    swap    defaults        0 0

tmpfs                   /dev/shm                tmpfs   defaults        0 0

devpts                  /dev/pts                devpts  gid=5,mode=620  0 0

sysfs                   /sys                    sysfs   defaults        0 0

proc                    /proc                   proc    defaults        0 0

挂载的设备        挂载点     挂载的文件系统类型   参数   备份 检查

挂载的设备,可以是设备名或UUID,或磁盘标签

[root@localhost ~]# df -h  ===以人类可读的信息查看磁盘挂载信息

Filesystem      Size  Used Avail Use% Mounted on

/dev/sda3       9.2G  1.8G  7.0G  20% /

tmpfs           491M     0  491M   0% /dev/shm

/dev/sda1       194M   29M  155M  16% /boo

 

挂载:

1、命令行手动:

mount -t ext4 -o noexec /dev/sda1/mnt

2、放在/etc/fstab 里面

 

测试手动挂载步骤:

1、创建一个虚拟的块设备

dd if=/dev/zero of=/dev/sdb1 bs=4096 count=100

2、格式化

mkfs.ext4 /dev/sdb1

3、挂载

mount -t ext4 -o loop,noatime,noexec /dev/sdb1 /mnt    特殊设备要用loop

4、查看

df –h

fstab出问题,修复:

1、开机提示,输入密码 修复。

2、救援模式,rescue

修改/etc/fstab只读状态,mount  -o rw,remout /

 

Mount挂载:和fstab问题

NFS网络文件系统挂载时,网卡还没起,就已经加载fstab,所以只能放进/etc/rc.local,因为他是最后启动的

 CentOS7已经不会出现这个问题

 

2.10 /etc/rc.local

让一个程序开机启动:

1)  chkconfig(/etc/init.d/sshd)

2)  放入/etc/rc.local

选择建议:/etc/rc.local

我们把/etc/rc.local,服务器档案文件。

所有程序开机启动放入/etc/rc.local,注释。

 

2.11 /etc/inittab

/etc/inittab 设定系统启动时init进程将把系统设置成什么样的runlevel运行级别及加载相关级别对应启动文件设置

 

口头描述linux的开机到登录界面的启动过程:

1、开机BIOS自检

2MBR引导

3grub引导菜单,选择引导哪个操作系统

4、加载内核kernel

5、启动init进程

6、读取inittab文件,执行rc.sysinitrc等脚本

/etc/inittab

/etc/rc.d/rc.sysinit

/etc/rc.d/rc3.d <=====文本模式

7、启动mingetty,进入系统登陆界面

linux目录结构详细介绍_笔记_02

2.12 chkconfig,runlevel

装完系统后,希望让网络文件共享服务NFS,仅在3级别开机自启动,该如何做?

[root@localhost ~]# chkconfig sshd on

[root@localhost ~]# chkconfig --list sshd

sshd            0:off   1:off   2:on    3:on    4:on    5:on    6:off

[root@localhost ~]# chkconfig sshd off  

[root@localhost ~]# chkconfig --list sshd

sshd            0:off   1:off   2:off   3:off   4:off   5:off   6:off

[root@localhost ~]# chkconfig --level 35 sshd on

[root@localhost ~]# chkconfig --list sshd      

sshd            0:off   1:off   2:off   3:on    4:off   5:on    6:off

 

[root@localhost ~]# chkconfig --level 3 sshd off

[root@localhost ~]# ls -l /etc/rc3.d/|grep ssh

lrwxrwxrwx  1 root root 14 May 22 18:40 K25sshd -> ../init.d/sshd

[root@localhost ~]# chkconfig --level 3 sshd on

[root@localhost ~]# ls -l /etc/rc3.d/|grep ssh

lrwxrwxrwx  1 root root 14 May 22 18:40 S55sshd -> ../init.d/sshd

[root@localhost ~]# rm -f /etc/rc3.d/S55sshd

[root@localhost ~]# ln -s /etc/init.d/sshd  /etc/rc3.d/K25sshd

[root@localhost ~]# chkconfig --list sshd

sshd            0:off   1:off   2:off   3:off   4:off   5:on    6:off

chkconfig管理脚本的要求

1、执行 /etc/init.d/sshd restart 格式正常服务

2、脚本里开头增加如下

#chkconfig:35 56 24

#description:yuehan linux test.

chkconfig管理脚本实例:

1)创建脚本,并放入/etc/init.d/

[root@localhost yuehan]# cd /etc/rc.d/rc3.d/

[root@localhost rc3.d]# vim /etc/init.d/test

# chkconfig: 2345 56 24              =====5624分别代表服务开关的执行编号

# description: test by wangxin              =====chkconfig管理,必须加这两行

echo linux chkconfig test

2)给脚本增加权限

[root@localhost rc3.d]# /etc/init.d/test   

-bash: /etc/init.d/test: Permission denied

[root@localhost rc3.d]# chmod +x /etc/init.d/test  

[root@localhost rc3.d]# /etc/init.d/test        

linux chkconfig test

[root@localhost rc3.d]# /etc/init.d/test start

linux chkconfig test

3)添加到chkconfig管理列表

[root@localhost rc3.d]# chkconfig --add test 

[root@localhost rc3.d]# chkconfig --list test

test            0:off   1:off   2:on    3:on    4:on    5:on    6:off

[root@localhost rc3.d]# ll /etc/rc.d/rc3.d/|grep test

lrwxrwxrwx   1 root root   14 Mar  7 06:50 S56test -> ../init.d/test

[root@localhost rc3.d]# chkconfig test off          

[root@localhost rc3.d]# ll /etc/rc.d/rc3.d/|grep test

lrwxrwxrwx   1 root root   14 Mar  7 06:52 K24test -> ../init.d/test

特别注意:

/etc/init.d/sshd start 让程序当前运行

chkconfig是管理程序是否开机启动

两者没有什么关系

 

linux系统运行级别一般为0~6,请分别写出每个级别的含义

0----关机模式

1----单用户模式

2----NFS的多用户模式

3----文本模式,完整的多用户模式

4----未使用的

5----图形模式

6----重启模式