本文主要是介绍ext和xfs类型文件恢复和日志分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
一、概述
1、inode和block概述
文件数据包括元信息与实际数据
文件存储在硬盘上,硬盘最小存储单位是“扇区”,每个扇区存储512字节
block(块)
连续的八个扇区组成一个block(4K)
是文件存取的最小单位
inode(索引节点)
中文译名为“索引节点”,也叫i节点
用于存储文件元信息
2、inode内容
inode包含文件的元信息
文件的字节数
文件拥有者的User lD(不包含文件名)
文件的Group lD
文件的读、写、执行权限
文件的时间戳
目录文件的结构
目录也是一种文件
目录文件的结构
每个inode都有一个号码,操作系统用inode号码来识别不同的文件
Linux系统内部不使用文件名,而使用inode号码来识别文件
对于用户,文件名只是inode号码便于识别的别称
●查看文件的inode信息
ls -i 文件
stat 文件
Linux系统文件三个主要的时间属性
1.atime(access time)
最后一次访问文件或目录的时间
2.mtime(modify time)
最后一次更改文件或目录(内容)的时间
3.ctime(change time)
最后一次改动文件或目录(属性)的时间
由于inode号码与文件名分离,导致Linux系统具备以下几种特有的现象:
1.文件名包含特殊字符,可能无法正常删除。这时直接删除 inode,能够起到删除文件的作用。
2.移动文件或重命名文件,只是改变文件名,不影响inode号码。
3.打开一个文件以后,系统就以 inode号码来识别这个文件,不再考虑文件名。
4.文件数据被修改保存后,会生成一个新的inode号码。
模拟inode节点耗尽
1、关闭虚拟机,编辑虚拟机设置,添加新硬盘,点击下一步并确认,开启虚拟机
2查看磁盘列表
3创建磁盘
格式化
创建目录和挂载
查看
查看inode号
模拟inode节点耗尽故障
删除恢复
实例:EXT类型文件恢复
extundelete 是一个开源的Linux数据恢复工具,支持 ext3、ext4文件系统。(ext4只能在centos6版本恢复)#使用fdisk创建分区/dev/sdb1,格式化ext3文件系统。
创建sdb2
格式化+挂载+安装yum
下载压缩包,下载好后将压缩包拖入Xshell中,在哪个目录下执行的,压缩包就在哪个目录下
将压缩包复制到/sdb2中并切换到/sdb2进行解压缩,再切换进入extundelete目录中将configure进行编译安装
5、创建软链接,在/sdb2中创建文件写入内容,并查询inode号
模拟删除,并使用工具恢复内容,恢复之前需解挂载,恢复的是磁盘内的内容
xfs类型文件修复
●CentOS 7 系统默认采用 xfs类型的文件,xfs 类型的文件可使用 xfsdump 与 xfsrestore 工具进行备份恢复。
●xfsdump 命令常用的选项:
-f:指定备份文件目录
-L:指定标签 session label
-M:指定设备标签 media label
-s:备份单个文件,-s 后面不能直接跟路径
●xfsdump使用限制:
1.只能备份已挂载的文件系统
2.必须使用root的权限才能操作
3.只能备份XFS文件系统
4.备份后的数据只能让xfsrestore解析
5.不能备份两个具有相同UUID的文件系统(可用 blkid命令查看)
实验
创建分区
格式化,挂载
安装yum包
模拟并恢复
日志文件
1、日志的功能
1.用于记录系统、程序运行中发生的各种事件
2.通过阅读日志,有助于诊断和解决系统故障
2 、日志文件的分类
1.内核及系统日志
由系统服务rsyslog统一进行管理,日志格式基本相似主配置文件letc/rsyslog.conf
2.用户日志
记录系统用户登录及退出系统的相关信息
3.程序日志
由各种应用程序独立管理的日志文件,记录格式不统一
3、常见的日志文件
内核及系统日志由系统服务rsyslog统一管理,主配置文件为/etc/rsyslog.confLinux操作系统本身和大部分服务器程序的日志文件都默认放在目录/var/log/下。
常见的一些日志文件:
#内核及公共消息日志:
/var/log/messages:记录Linux内核消息及各种应用程序的公共日志信息,包括启动、Io错误、网络错误、程序故障等。对于未使用独立H应用程序或服务,一般都可以从该日志文件中获得相关的事件记录信息。
#计划任务日志:
/var/log/cron:记录crondiE划任务产生的事件信息。
#系统引导日志:
/var/log/dmesg: 记录Linux系统在引导过程中的各种事件信息。
#邮件系统日志:
/var/log/maillog:记录进入或发出系统的电子邮件活动。
#用户登录日志:
/var/log/secure:记录用户认证相关的安全事件信息。
/var/log/lastlog:记录每个用户最近的登录事件。二进制格式
/var/log/wtmp:记录每个用户登录、注销及系统启动和停机事件。二进制格式
/var/run/btmp:记录失败的、错误的登录尝试及验证事件。二进制格式
#查看rsyslog.conf配置文件
vim /etc/rsyslog.conf
*.info; mail.none; authpriv.none ; cron.none
/ var / log / messages
*.info#表示info等级及以上的所有等级的信息都写到对应的日志文件里mail.none
#表示某事件的信息不写到日志文件里(这里比如是邮件)
4、日志优先级
Linux系统内核日志消息的优先级别(数字等级越小,优先级越高,消息越重要)﹔
0 EMERG(紧急):会导致主机系统不可用的情况。
1 ALERT(警告):必须马上.采取措施解决的问题。
2 CRIT(严重) : 比较严重的情况。
3 ERR(错误):运行出现错误。
4 WARNING(提醒):可能影响系统功能,需要提醒用户的重要事件。
5 NOTICE(注意):不会影响正常功能,但是需要注意的事件。
6 INFO (信息):—般信息。
7 DEBUG (调试):程序或系统调试信息等。
这篇关于ext和xfs类型文件恢复和日志分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!