2.1 目录结构图
2.2 /目录
目录 | 描述 |
/ | 第一层次结构的根、整个文件系统层次结构的根目录。 |
/bin/ | |
/dev/ | |
/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/ | 变量文件——在正常运行的系统中其内容不断变化的文件,如日志,脱机文件和临时电子邮件文件。有时是一个单独的分区。如果不单独分区,有可能会把整个分区充满。如果单独分区,给大给小都不合适。 |
2.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/ | 默认创建用户时,把该目录拷贝到家目录下 |
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自检
2、MBR引导
3、grub引导菜单,选择引导哪个操作系统
4、加载内核kernel
5、启动init进程
6、读取inittab文件,执行rc.sysinit,rc等脚本
/etc/inittab
/etc/rc.d/rc.sysinit
/etc/rc.d/rc3.d <=====文本模式
7、启动mingetty,进入系统登陆界面
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 《=====56,24分别代表服务开关的执行编号
# 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----重启模式