Linux 文件系统与日志分析

一、深入理解Linux文件系统

在处理 Linux 系统出现的各种故障时,故障的症状是最易发现的,而导致这一故障的原
因才是最终排除故障的关键。熟悉 Linux 系统中常见的日志文件,了解一般故障的分析与解
决办法,将有助于管理员快速定位故障点、 对症下药 、并及时解决各种系统问题。另外,
Linux 系统中通过分区、格式化来创建文件系统,而文件系统的运行又与 block inode
关。

1. inode block 详解

操作系统的文件数据除了实际内容之外,通常含有非常多的属性,例如 Linux 操作系统的文件权限(rwx )与文件属性(所有者、群组、时间参数等)。文件系统通常会将这两部分内容分别存放在 inode block 中。

(1)inode block 概述

文件是存储在硬盘上的,硬盘的最小存储单位叫做 扇区 sector ),每个扇区存储 512字节。操作系统读取硬盘的时候,不会一个个扇区地读取,这样效率太低,而是一次性连续读取多个扇区,即一次性读取一个" " block )。这种由多个扇区组成的 " " ,是文件存取的最小单位。" " 的大小,最常见的是 4KB ,即连续八个 sector 组成一个 block。
文件数据存储在“ 中,那么还必须找到一个地方存储文件的元信息,比如文件的创建者、文件的创建日期、文件的大小等等。这种存储文件元信息的区域就叫做 inode ,中文译名为“ 索引节点 ,也叫 i 节点。因此,一个文件必须占用一个 inode ,但至少占用一个 block。

xfs的分区,一个inode有512字节,一个block有4096字节

ext4的分区,一个inode有256字节,一个block有4096字节

(2)inode 的内容

[root@localhost ~]# stat anaconda-ks.cfg

  文件:"anaconda-ks.cfg"

  大小:1683       块:8          IO 块:4096   普通文件

设备:fd00h/64768d Inode:268634178   硬链接:1

权限:(0600/-rw-------)  Uid:(    0/    root)   Gid:(    0/    root)

环境:system_u:object_r:admin_home_t:s0

最近访问:2022-05-22 19:04:21.392496430 +0800

最近更改:2022-05-22 19:04:21.395496615 +0800

最近改动:2022-05-22 19:04:21.395496615 +0800

创建时间:-

注释:
File:显示文件名
Size:显示文件大小
Blocks:文件使用的数据块总数
IO Block:IO块大小
regular file:文件类型(常规文件)
Device:设备编号
Inode:Inode号
Links:链接数
Access:文件的权限
Gid、Uid:文件所有权的Gid和Uid
access time:表示我们最后一次访问(仅仅是访问,没有改动)文件的时间
modify time:表示我们最后一次修改文件的时间
change time:表示我们最后一次对文件属性改变的时间,包括权限,大小,属性等等

2.硬链接与软链接

Linux 系统下的链接文件有两种,一种类似于 Windows 的快捷方式功能的文件,可以快速连接到目标文件或目录,称之为软链接;另一种则是通过文件系统的 inode 链接来产生的新文件名,而不是产生新文件,称之为硬链接。

(1)硬链接

一般情况下,文件名和 inode 号码是一一对应关系,每个 inode 号码对应一个文件名。但是 Linux 系统允许多个文件名指向同一个 inode 号码。这意味着,可以用不同的文件名访问同样的内容。ln 命令可以创建硬链接,命令的基本格式为:
ln 源文件 目标
运行该命令以后,源文件与目标文件的 inode 号码相同,都指向同一个 inode inode 信息中的“ 链接数 这时就会增加 1 。当一个文件拥有多个硬链接时,对文件内容修改,会影响到所有文件名;但是删除一个文件名,不影响另一个文件名的访问。删除一个文件名,只会使得 inode 中的 " 链接数 " 1 。需要注意的是不能对目录做硬链接。通过 mkdir 命令创建一个新目录 /app/kgc ,其硬链接数应该有 2 个,因为常见的目录本身为 1 个硬链接,而目录 kgc 下面的隐藏目录 . (点号)是该目录的又一个硬链接,也算是1 个连接数。

(2)软链接

软链接就是再创建一个独立的文件,而这个文件会让数据的读取指向它连接的那个文件的文件名。例如,文件 A 和文件 B inode 号码虽然不一样,但是文件 A 的,内容是文件B 的路径。读取文件 A 时,系统会自动将访问者导向文件 B 。这时,文件 A 就称为文件 B的“ 软链接 soft link )或者 符号链接( symbolic link )。这意味着,文件 A 依赖于文件 B 而存在,如果删除了文件 B ,打开文件 A 就会报错。这是软链接与硬链接最大的不同:文件 A 指向文件 B 的文件名,而不是文件 B inode 号码,文件 B inode“ 链接数 不会因此发生变化。
软链接的创建命令的基本格式为:
ln -s 源文件或目录 目标文件或目录

3.EXT 类型文件恢复

删除一个文件,实际上并不清除 inode 节点和 block 的数据,只是在这个文件的父目录里面的 block 中,删除这个文件的名字。 Linux 是通过 Link 的数量来控制文件删除的,只有当一个文件不存在任何 Link 的时候,这个文件才会被删除。
在数据被误删除后,第一时间要做的就是卸载被删除数据所在的分区,如果是根分区的数据遭到误删,就需要将系统进入单用户模式,并且将根分区以只读模式挂载。这样做的原因很简单,因为将文件删除后,仅仅是将文件的 inode 节点中的扇区指针清零,实际文件还存储在磁盘上,如果磁盘继续以读写模式挂载,这些已删除的文件的数据块就可能被操作系 统重新分配出去,在这些数据库被新的数据覆盖后,这些数据就真的丢失了,恢复工具也回天无力。所以以只读模式挂载磁盘可以尽量降低数据库中数据被覆盖的风险,以提高恢复数据成功的比例。
下面将介绍使用 extundelete 工具如何恢复误删除的文件。

(1)编译安装extundelete

在编译安装 extundelete 之前需要先安装两个依赖包 e2fsprogs-libs e2fsprogs-devel ,这两个包在系统安装光盘的/Package 目录下就有,使用 rpm yum 命令将其安装。
e2fsprogs-devel 安装依赖于 libcom_err-devel 包。
yum -y install e2fsprogs-devel e2fsprogs-libs
安装完依赖包之后,即可将提前上传的 extundelete 软件包解压、配置、编译、安装。

(2)模拟删除并执行恢复操作

1) 使用 fdisk 命令创建新分区,将其挂载到 /aaa 目录下,往该目录下新建一些文件或目录。
mkdir /aaa
[root@localhost ~]# mount /dev/sdb1 /aaa
[root@localhost ~]# cd /aaa
[root@localhost aaa]# echo a>a
[root@localhost aaa]# echo a>b
[root@localhost aaa]# echo a>c
[root@localhost aaa]# echo a>d
[root@localhost aaa]# ls
a b c d lost+found
2 )模拟误操作并恢复
使用 "rm -rf a b" 命令删除 /tmp/ 下的 a 文件和 b 文件,当出现误操作时,立刻卸载该文件系统,然后使用“ extundelete /dev/sdb1 --restore-all" 恢复 /dev/sdb1 文件系统下的所有内容。
[root@localhost aaa]# rm -rf a b
[root@localhost aaa]# ls
c d lost+found
[root@localhost aaa]# cd
[root@localhost ~]# umount /aaa
[root@localhost ~]# extundelete /dev/sdb1 --restore-all
NOTICE: Extended attributes are not restored. Loading filesystem metadata ... 160 groups loaded. Loading journal descriptors ... 26 descriptors loaded. Searching for recoverable inodes in directory / ... 2 recoverable inodes found. Looking through the directory structure for deleted files ... 
0 recoverable inodes still lost
执行完恢复的命令后,在当前目录下会出现一个 /RECOVERED_FILES/ 目录,里面保存了已经恢复的文件。

(4)xfs 类型文件备份和恢复

extundelete 工具仅可以恢复 EXT 类型的文件,无法恢复 CentOS 7 系统默认采用 xfs 类型的文件。针对 xfs 文件系统目前也没有比较成熟的文件恢复工具,所以建议提前做好数据备份,以避免数据丢失。
xfs 类型的文件可使用 xfsdump xfsrestore 工具进行备份恢复。若系统中未安装xfsdump与 xfsrestore 工具,可以通过 yum install -y xfsdump 命令安装。xfsdump 按照 inode顺序备份一个 xfs 文件系统。 xfsdump 的备份级别有两种: 0 表示完全备份; 1-9 表示增量备份。xfsdump 的备份级别默认为 0 xfsdump 的命令格式为:
xfsdump -f 备份存放位置
要备份路径或设备文件。常用的备份参数包括以下几种:
-f :指定备份文件目录;
-L :指定标签 session label
-M :指定设备标签 media label
-s :备份单个文件, -s 后面不能直接跟路径。
下面通过一个案例来备份恢复 xfs 类型的文件。首先添加一款新硬盘并格式化为 xfs 类型的文件系统,然后挂在到/data 目录下。
[root@localhost ~]# mkdir /data
[root@localhost ~]# mount /dev/sdb1 /data
[root@localhost ~]# cd /date
[root@localhost data]# cp /etc/passwd ./
[root@localhost data]# mkdir test
[root@localhost data]# touch test/a
使用 xfsdump 命令备份整个分区。
xfsdump -f /opt/dump_sdb1 /dev/sdb1
删除之前创建的内容,模拟数据丢失。
[root@localhost ~]# cd /data
[root@localhost data]# ls
passwd test
[root@localhost data]# rm -rf ./*
[root@localhost data]# ls
使用 xfsrestore 命令恢复文件。 xfsrestore 命令的语法为:
xfsrestore -f 恢复文件的位置 存放恢复后文件的路径
使用 xfsdump 时,需要注意以下的几个限制:
xfsdump 不支持没有挂载的文件系统备份,所以只能备份已挂载的;
xfsdump 必须使用 root 的权限才能操作 ( 涉及文件系统的关系 )
xfsdump 只能备份 XFS 文件系统;
xfsdump 备份下来的数据 ( 档案或储存媒体 ) 只能让 xfsrestore 解析;
xfsdump 是透过文件系统的 UUID 来分辨各个备份档的,因此不能备份两个具有相同UUID的文件系统。

二、分析日志文件

日志文件是用于记录 Linux 操作系统中各种运行消息的文件,相当于 Linux 主机的 日 记” 。不同的日志文件记载了不同类型的信息,如 Linux 内核消息、用户登录事件、程序错误等。
日志文件对于诊断和解决系统中的问题很有帮助,因为在 Linux 操作系统中运行的程序通常会把系统消息和错误消息写入相应的日志文件,这样系统一旦出现问题就会“ 有据可查 。此外,当主机遭受攻击时,日志文件还可以帮助寻找攻击者留下的痕迹。本节将对 Linux 操作系统中的主要日志文件及分析方法进行介绍。

1.主要日志文件

本小节将简单介绍日志数据的种类及常见日志文件的用途。在 Linux 操作系统中,日志 数据主要包括以下三种类型。
内核及系统日志:这种日志数据由系统服务 rsyslog 统一管理,根据其主配置文件/etc/rsyslog.conf 中的设置决定将内核消息及各种系统程序消息记录到什么位置。系统中有相当一部分程序会把自己的日志文件交由 rsyslog 管理,因而这些程序使用的日志记录也具有相似的格式。
用户日志:这种日志数据用于记录 Linux 操作系统用户登录及退出系统的相关信息,包括用户名、登录的终端、登录时间、来源主机、正在使用的进程操作等。
程序日志:有些应用程序会选择由自己独立管理一份日志文件(而不是交给 rsyslog服务管理),用于记录本程序运行过程中的各种事件信息。由于这些程序只负责管理自己的日志文件,因此不同程序所使用的日志记录格式可能会存在较大的差异。
Linux 操作系统本身和大部分服务器程序的日志文件都默认放在目录 /var/log/ 下。一部分程序共用一个日志文件,一部分程序使用单个日志文件,而有些大型服务器程序由于日志文件不止一个,所以会在/var/log/ 目录中建立相应的子目录来存放日志文件,这样既保证了日志文件目录的结构清晰,又可以快速定位日志文件。有相当一部分日志文件只有 root 用户才有权限读取,这保证了相关日志信息的安全性
对于 Linux 操作系统中的日志文件,有必要了解其各自的用途,这样才能在需要的时候更快地找到问题所在,及时解决各种故障。下面介绍常见的一些日志文件。
/var/log/messages :记录 Linux 内核消息及各种应用程序的公共日志信息,包括启动、I/0 错误、网络错误、程序故障等。对于未使用独立日志文件的应用程序或服
务,一般都可以从该日志文件中获得相关的事件记录信息。
/var/log/cron :记录 crond 计划任务产生的事件信息。
/var/log/dmesg :记录 Linux 操作系统在引导过程中的各种事件信息。
/var/log/maillog :记录进入或发出系统的电子邮件活动。
/var/log/lastlog :记录每个用户最近的登录事件。
/var/log/secure :记录用户认证相关的安全事件信息。
/var/log/wtmp :记录每个用户登录、注销及系统启动和停机事件。
/var/log/btmp :记录失败的、错误的登录尝试及验证事件。

2.日志文件分析

对于大多数文本格式的日志文件(如内核及系统日志、大多数的程序日志),只要使用tail、 more less cat 等文本处理工具就可以查看日志内容。而对于一些二进制格式的日志文件(如用户日志),则需要使用特定的查询命令。

(1)内核及系统日志

内核及系统日志功能主要由默认安装的 rsyslog-7.4.7-16.el7.x86_64.rpm 软件包提供。rsyslog 服务所使用的配置文件为 /etc/rsyslog.conf 。通过查看 /etc/rsyslog.conf 文件中的内容,可以了解到系统默认的日志设置。
rsyslogd 服务管理的日志文件都是 Linux操作系统中主要的日志文件,它们记录了 Linux 操作系统中内核、用户认证、电子邮件、计划任务等基本的系统消息。在 Linux 内核中,根据日志消息的重要程度不同,将其分为不同的优先级别(数字等级越小,优先级越高,消息越重要)。
0 EMERG (紧急):会导致主机系统不可用的情况。
1 ALERT (警告):必须马上采取措施解决的问题。
2 CRIT (严重):比较严重的情况。
3 ERR (错误):运行出现错误。
4 WARNING (提醒):可能影响系统功能,需要提醒用户的重要事件。
5 NOTICE (注意):不会影响正常功能,但是需要注意的事件。
6 INFO (信息):一般信息。
7 DEBUG (调试):程序或系统调试信息等。
对于 rsyslog 服务统一管理的大部分日志文件,使用的日志记录格式基本上是相同的。以公共日志/var/log/messages 文件的记录格式为例,其中每一行表示一条日志消息,每一条消息均包括以下四个字段。
时间标签:消息发出的日期和时间。
主机名:生成消息的计算机的名称。
子系统名称:发出消息的应用程序的名称。
消息:消息的具体内容。

(2)用户日志

wtmp btmp、 lastlog 等日志文件中,保存了系统用户登录、退出等相关的事件消息。但是这些文件都是二进制的数据文件,不能直接使用 tail less 等文本查看工具进行浏览,需要使用 who w users last lastb 等用户查询命令来获取日志信息。
1)查询当前登录的用户情况——userswhow 命令
users 命令只是简单地输出当前登录的用户名称,每个显示的用户名对应一个登录会话。 如果一个用户有不止一个登录会话,那他的用户名将显示与其相同的次数。
[root@localhost ~]# users
root root root //root 用户打开三个终端
who 命令用于报告当前登录到系统中的每个用户的信息。使用该命令,系统管理员可以查看当前系统存在哪些不合法用户,从而对其进行审计和处理。who 的默认输出包括用户名、终端类型、登录日期及远程主机。
[root@localhost ~]# who
root :0    2017-05-07 10:27 (:0)
root pts/1 2017-05-07 10:27 (:0)
root pts/2 2017-05-07 10:28 (192.168.12.1)
w 命令用于显示当前系统中的每个用户及其所运行的进程信息,比 users who 命令的输出内容要丰富一些。
[root@localhost ~]# w
11:48:26 up 1:32, 3 users, load average: 0.03, 0.02, 0.05
USER     TTY        FROM                    LOGIN@  IDLE  JCPU  PCPU WHAT
root     :0      :0                     10:27 ?xdm? 51.22s 0.27s gdm-session-worker
[pam/gdm-password]
root     pts/1   :0                     10:27 1:20m 0.02s 0.02s bash
root     pts/2   192.168.12.1         10:28 2.00s 0.65s 0.04s w
2)查询用户登录的历史记录——lastlastb 命令
last 命令用于查询成功登录到系统的用户记录,最近的登录情况将显示在最前面。通过last 命令可以及时掌握 Linux 主机的登录情况,若发现未经授权的用户登录过,则表示当前主机可能已被入侵。
lastb 命令用于查询登录失败的用户记录,如登录的用户名错误、密码不正确等情况都将记录在案。登录失败的情况属于安全事件,因为这表示可能有人在尝试猜解你的密码。除了使用 lastb 命令查看以外,也可以直接从安全日志文件 /var/log/secure 中获得相关信息。

(3)程序日志

Linux 操作系统中,还有相当一部分应用程序没有使用 rsyslog 服务来管理日志,而是由程序自己维护日志记录。总的来说,作为一名合格的系统管理人员,应该提高警惕,随时注意各种可疑状况,定 期并随机检查各种系统日志文件,包括一般信息日志、网络连接日志、文件传输日志及用户
登录日志记录等。在检查这些日志时,要注意是否有不合常理的时间或操作记录。例如,出现以下现象就应多加注意。
用户在非常规的时间登录,或者用户登录系统的 IP 地址和以往的不一样。
用户登录失败的日志记录,尤其是那些一再连续尝试进入失败的日志记录。
非法使用或不正当使用超级用户权限。
无故或者非法重新启动各项网络服务的记录。
不正常的日志记录,如日志残缺不全,或者是诸如 wtmp 这样的日志文件无故缺少了中间的记录文件。
另外,需要提醒管理人员注意的是,日志并不是完全可靠的,高明的黑客在入侵系统后经常会打扫现场。所以管理人员需要综合运用以上的系统命令,全面、综合地进行审查和检测,切忌断章取义,否则将可能做出错误的判断。
  • 21
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值