centos debugfs,centos nfs挂载
大家好,今天给各位分享centos debugfs的一些知识,其中也会对centos nfs挂载进行解释,文章篇幅可能偏长,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在就马上开始吧!
如何理解linux原生跟踪工具ftrace的原理
前言:ftrace是一个内核追踪工具,帮助开发者深入理解内核行为,分析性能问题。它能追踪内核事件、动态函数调用及函数调用栈,适用于系统级性能分析。
一、ftrace基本概念
在 Linux内核中,ftrace是用于追踪系统事件、函数调用及调用栈的工具。通过 ftrace,开发者能详细分析内核运行状态,定位性能瓶颈。
二、ftrace使用方法
要使用 ftrace,首先确保系统的 debugfs或 tracefs已经挂载。在较旧版本的内核(如 CentOS 7)中,debugfs通常位于/sys/kernel/debug,而在较新内核(如 Ubuntu 16.04,内核版本 4.13)中,tracefs挂载于/sys/kernel/tracing,建议将此目录 link到/tracing。
使用 ftrace需激活内核相关选项,通常在较新内核版本中通过配置文件完成。传统 Tracer包括 Function、Function Graph和 nop等模式,通过控制文件配置追踪模式和跟踪特定函数。
1. Function Tracing
Function Tracing通过控制文件设置追踪函数。可以设置特定函数追踪,例如禁止跟踪包含"lock"的函数。
2. Function Graph Tracing
Function Graph Tracing提供更详细的函数调用关系视图,可以追踪特定函数的调用栈。
3. Event Tracing
Event Tracing用于追踪特定内核事件,通过目录中的 enable文件启用追踪。
4. Trace-cmd
Trace-cmd是 ftrace的前端工具,简化了 ftrace的使用,提供命令行操作追踪功能。
三、ftrace实现原理
ftrace的实现基于框架与一系列 tracer组件。框架负责管理 tracer,处理 trace信息,并通过 debugfs提供控制接口。Function Tracer通过 GCC的 profile功能,动态添加 trace代码到内核函数入口,实现动态追踪。
四、实战案例:隐藏的电灯开关
在一次性能问题排查中,Gregg通过 ftrace工具追踪发现,系统延迟问题与文件读取操作相关,具体为 readahead和 page fault。通过使用 ftrace,他定位到是文件读取时的读取页数过多,导致性能下降。进一步使用 kprobe跟踪函数参数,最终确认问题原因在于 readahead参数设置不当,修改后问题得到解决。
总结:ftrace是一个强大的内核分析工具,通过 ftrace,开发者能深入系统内部,定位和解决性能问题,提升系统效率。
Xtrabackup 能不能做单库的备份恢复
大数据量备份与还原,始终是个难点。当MYSQL超10G,用mysqldump来导出就比较慢了。在这里推荐xtrabackup,这个工具比mysqldump要快很多。一、Xtrabackup介绍 1、Xtrabackup是什么 Xtrabackup是一个对InnoDB做数据备份的工具,支持在线热备份(备份时不影响数据读写),是商业备份工具InnoDB Hotbackup的一个很好的替代品。 Xtrabackup有两个主要的工具:xtrabackup、innobackupex 1、xtrabackup只能备份InnoDB和XtraDB两种数据表,而不能备份MyISAM数据表 2、 innobackupex是参考了InnoDB Hotbackup的innoback脚本修改而来的.innobackupex是一个perl脚本封装,封装了xtrabackup。主要是为了方便的同时备份InnoDB和MyISAM引擎的表,但在处理myisam时需要加一个读锁。并且加入了一些使用的选项。如slave-info可以记录备份恢复后,作为slave需要的一些信息,根据这些信息,可以很方便的利用备份来重做slave。 2、Xtrabackup可以做什么:在线(热)备份整个库的InnoDB、 XtraDB表在xtrabackup的上一次整库备份基础上做增量备份(innodb only)以流的形式产生备份,可以直接保存到远程机器上(本机硬盘空间不足时很有用) MySQL数据库本身提供的工具并不支持真正的增量备份,二进制日志恢复是point-in-time(时间点)的恢复而不是增量备份。 Xtrabackup工具支持对InnoDB存储引擎的增量备份,工作原理如下:(1)首先完成一个完全备份,并记录下此时检查点的LSN(Log Sequence Number)。(2)在进程增量备份时,比较表空间中每个页的LSN是否大于上次备份时的LSN,如果是,则备份该页,同时记录当前检查点的LSN。首先,在logfile中找到并记录最后一个checkpoint(“last checkpoint LSN”),然后开始从LSN的位置开始拷贝InnoDB的logfile到xtrabackup_logfile;接着,开始拷贝全部的数据文件.ibd;在拷贝全部数据文件结束之后,才停止拷贝logfile。因为logfile里面记录全部的数据修改情况,所以,即时在备份过程中数据文件被修改过了,恢复时仍然能够通过解析xtrabackup_logfile保持数据的一致。因为innobackupex支持innodb,myisam,所以本文说一下,怎么使用innobackupex。二,安装xtrabackup 1、下载地址/downloads/XtraBackup/ 2、安装根据需求,选择不同的版本,我选择的是rpm安装包,如果报以下错误复制代码代码如下: [root@localhost xtrabackup]# rpm-ivh percona-xtrabackup-2.2.4-5004.el6.x86_64.rpm warning: percona-xtrabackup-2.2.4-5004.el6.x86_64.rpm: Header V4 DSA/SHA1 Signature, key ID cd2efd2a: NOKEY error: Failed dependencies: perl(Time::HiRes) is needed by percona-xtrabackup-2.2.4-5004.el6.x86_64解决办法:复制代码代码如下: [root@localhost xtrabackup]# yum-y install perl perl-devel libaio libaio-devel perl-Time-HiRes perl-DBD-MySQL//安装依赖包 [root@localhost xtrabackup]# rpm-ivh percona-xtrabackup-2.2.4-5004.el6.x86_64.rpm//重新安装 warning: percona-xtrabackup-2.2.4-5004.el6.x86_64.rpm: Header V4 DSA/SHA1 Signature, key ID cd2efd2a: NOKEY Preparing...########################################### [100%] 1:percona-xtrabackup########################################### [100%]
CentOS系统下尝试恢复被删除的文件的方法集锦
背景说明:今天同事在用ftp更新网站内容是,将原来文件夹重命名以备份,再上传文件,上传完成后测试网站可以访问就将备份删除(脑袋抽筋了),结果发现备份中最重要的一个图片文件夹被删除,而上传的只是程序文件,导致所有图片丢失。
找回办法如下:
1、尝试方法一:debugfs
用debugfs工具,可以看到删除的列表,但没有找到批量恢复文件的办法(丢失的文件有1万多),可能是我方法不对。对于单个文件,debugfs是可以很方便恢复的。
大多数Linux发行版都提供一个debugfs工具,可以用来对Ext3文件系统进行编辑操作。不过在使用这个工具之前,还有一些工作要做。
首先以只读方式重新挂载被误删的文件所在分区。使用如下命令:(假设文件在/usr分区)
复制代码代码如下:
mount-r-n-o remount/usr
-r表示只读方式挂载;-n表示不写入/etc/mtab,如果是恢复/etc上的文件,就加上这个参数。如果系统说xxx partion busy,可以用fuser命令查看一下是哪些进程使用这个分区上的文件:
复制代码代码如下:
fuser-v-m/usr
如果没有什么重要的进程,用以下命令停掉它们:
复制代码代码如下:
fuser-k-v-m/usr
然后就可以重新挂载这些文件系统了。
如果是把所有的文件统一安装在一个大的/分区当中,可以在boot提示符下用linux single进入单用户模式,尽量减少系统进程向硬盘写入数据的机会,要不干脆把硬盘挂在别的机器上。另外,恢复出来的数据不要写到/上面,避免破坏那些有用的数据。如果机器上有dos/windows,可以写到这些分区上面:
复制代码代码如下:
mount-r-n/dev/hda1/mnt/had
然后就可以执行debugfs:(假设Linux在/dev/hda5)
复制代码代码如下:
#debugfs/dev/hda5
就会出现debugfs提示符debugfs:
使用lsdel命令可以列出很多被删除的文件的信息:
debugfs:lsdel
debugfs: 2692 deleted inodes found.
Inode Owner Mode Size Blocks Time deleted
164821 0 100600 8192 1/ 1 Sun May 13 19:22:46 2001
…………………………………………………………………………………
36137 0 100644 4 1/ 1 Tue Apr 24 10:11:15 2001
196829 0 100644 149500 38/ 38 Mon May 27 13:52:04 2001
debugfs:
列出的文件有很多(这里找到2692个),第一字段是文件节点号,第二字段是文件所有者,第三字段是读写权限,接下来是文件大小,占用块数,删除时间。然后就可以根据文件大小和删除日期判断那些是我们需要的。比如我们要恢复节点是196829的文件:
可以先看看文件数据状态:
复制代码代码如下:
debugfs:stat
Inode: 196829 Type: regular Mode: 0644 Flags: 0×0 Version: 1
User: 0 Group: 0 Size: 149500
File ACL: 0 Directory ACL: 0
Links: 0 Blockcount: 38
Fragment: Address: 0 Number: 0 Size: 0
ctime: 0x31a9a574— Mon May 27 13:52:04 2001
atime: 0x31a21dd1— Tue May 21 20:47:29 2001
mtime: 0x313bf4d7— Tue Mar 5 08:01:27 2001
dtime: 0x31a9a574— Mon May 27 13:52:04 2001
BLOCKS:
594810 594811 594814 594815 594816 594817………………………………….
TOTAL: 38
然后就可以用dump指令恢复文件:
复制代码代码如下:
debugfs:dump/mnt/hda/01.sav
这样就把文件恢复出来了。退出debugfs:
复制代码代码如下:
debugfs:quit
另一种方法是手工编辑inode:
复制代码代码如下:
debugfs:mi
Mode [0100644]
User ID [0]
Group ID [0]
Size [149500]
Creation time [0x31a9a574]
Modification time [0x31a9a574]
Access time [0x31a21dd1]
Deletion time [0x31a9a574] 0
Link count [0] 1
Block count [38]
File flags [0x0]
Reserved1 [0]
File acl [0]
Directory acl [0]
Fragment address [0]
Fragment number [0]
Fragment size [0]
Direct Block#0 [594810]
…………………………….
Triple Indirect Block [0]
使用mi指令后每次显示一行信息以供编辑,其它行可以直接按回车表示确认,把deletion time改成0(未删除),Link count改成1。改好后退出debugfs:
复制代码代码如下:
debugfs:quit
然后用fsck检查/dev/hda5
复制代码代码如下:
fsck/dev/hda5
程序会说找到丢失的数据块,放在lost+found里面。
另外debugfs不适合恢复大文件。
2、尝试方法二、foremost
foremost是很不错的软件,非常简单,一个命令就恢复了所有图片,但是文件名却丢失了,那么多图片如何恢复名字,没有找到好的办法。同上面debugfs一样,如果是单个文件,或者知道文件名字,这个方法是可以的。但文件量过大,且必须恢复文件名,此方法则不行。
基本使用办法如下:
下载并编译安装 foremost:
复制代码代码如下:
[root@b2bapp1~]# wget
[root@b2bapp1~]# tar xf foremost-1.5.7.tar.gz-C/usr/src/
[root@b2bapp1~]# cd/usr/src/foremost-1.5.7/
[root@crushlinux foremost-1.5.7]# make&& make install
[root@b2bapp1~]# foremost-t png-i/dev/mapper/VolGroup-lv_root
Processing:/dev/mapper/VolGroup-lv_root
恢复完成后会在你的当前所在目录中建立一个 output目录,并在在 output目录下会建立 png子目录下会包括所有已经恢复回来的 png格式的文件。
注意:恢复回来的文件,文件名已经改变,另外 output目录下有一个 audit.txt文件是恢复成功文件的列表。
3、尝试方法三、extundelete
在网上终于找到一个非常优秀的恢复软件extundelete,通过它,我恢复了绝大部分软件(分部被覆盖导致丢失)。操作方法如下:
安装软件:
软件下载地址:
复制代码代码如下:
yum install e2fsprogs-devel libcom_err-devel-y
tar-jxf extundelete-0.2.4.tar.bz2
cd extundelete-0.2.4
./configure
make
make install
执行恢复动作:
复制代码代码如下:
[root@b2bapp1~]# extundelete/dev/mapper/VolGroup-lv_root--restore-all
上述命令表示恢复上述分区下的所有近期删除文件,我通过此办法找回了99%的文件,还有少数被覆盖。
extundelete其他主要用法:
单个文件的恢复:
复制代码代码如下:
extundelete/dev/sdaX--restore-file/path/file
目录恢复:
复制代码代码如下:
extundelete/dev/sdaX--restore-directory/path/dir
教训经验:
文件被删除后,恢复建议如下:
1、停止所有写入(可断网防止外部新的访问进入),最好将磁盘dd克隆一份。我们丢失的文件就是因为同事急于恢复,进行一些操作导致部分数据被覆盖。
2、如果被删除的文件被进程使用中,则千万别关闭该进程,用losf配合可以找回(因为还在内存中),这种恢复办法网上很多教程。
3、用合适的工具恢复。
复制代码代码如下:
[root@b2bapp1~]# wget
[root@b2bapp1~]# tar xf foremost-1.5.7.tar.gz-C/usr/src/
[root@b2bapp1~]# cd/usr/src/foremost-1.5.7/
[root@crushlinux foremost-1.5.7]# make&& make install
[root@b2bapp1~]# foremost-t png-i/dev/mapper/VolGroup-lv_root
Processing:/dev/mapper/VolGroup-lv_root