linux使用fsck修复文件系统
1、问题描述
服务器maint_samba
由于服务器maint_samba (debian操作系统)没有正常关机,在重新启动过程中/dev/sdb1出现文件系统错误,需要手动使用fsck进行扫描和修复。出现如下情况:
…...
Checking file systems ...fsck 1.41.3(12-OCT-2008)
/dev/sdb1 contains a file system with errors check forced
/dev/sdb1: |========== 百分数%
……
/dev/sdb1: UNEXPECTED INCONSISTENCY; RUN fsck MANUALLY (i.e.,without -a or -p options)
fsck died with exit status4
……
……/var/log/fsck/fsck ---fsck报错日志的存放位置
……
Warning
……
Press enter for maintenance
(or type Control-D to continue): --- Ctrl+d继续启动服务器。
2、手动fsck修复
2.1 fsck简介
fsck不仅可以对文件系统进行扫描,还能修正文件系统的一些问题。值得注意的是fsck 扫描文件系统时一定要在单用户模式、修复模式或把设备umount后进行。
警告:如果扫描运行中的系统,会造成系统文件损坏。
文件系统扫描工具有 fsck,fsck.ext2,fsck.jfs,fsck.msdos,fsck.vfat,fsck.ext3,fsck.reiserfs(reiserfsck)。其中fsck 默认支持文件系统ext2,如果想支持ext3文件系统的扫描,应该加-j 参数。最好是根据不同的文件系统来调用不同的扫描工具,比如ext3的文件系统使用fsck.ext3,ext2文件系统使用fsck.etx2等。
/dev/sdb1是ext3的文件系统,只介绍fsck.ext3
fsck.ext3
[语法]
fsck.ext3[必要参数][选择参数][设备代号]
[功能]
fsck.ext3 命令:
针对ext3型文件系统进行检测
[执行权限]
超级用户普通用户
[参数]
必要参数
-a 非互交模式,自动修复
-c 检查是否存在有损坏的区块。
-C<反叙述器> fsck.ext3命令会把全部的执行过程,都交由其逆向叙述,便于监控程序
-d 详细显示命令执行过程
-f 强制进行检查
-F 检查文件系统之前,先清理该保存设备块区内的数据
-l<损坏区块文件> 把文件中所列出的损坏区块,加入标记
-L<损坏区块文件> 清除所有损坏标志,重新标记
-n 非交互模式,把欲检查的文件系统设成只读
-P<数字> 设置fsck.ext2命令所能处理的inode大小为多少
-r 交互模式
-R 忽略目录
-s 顺序检查
-S 效果和指定“-s”参数类似
-t 显示fsck.ext2命令的时序信息。
-v 显示详细的处理过程
-y 关闭互动模式
选择参数
-b<分区第一个磁区地址> 指定分区的第一个磁区的起始地址/Super Block
-B<区块大小> 设置该分区每个区块的大小
-I设置欲检查的文件系统,其inode缓冲区的区块数目
-V显示版本信息
[参考范例]
范例1: 检测磁盘
[root@linux test]# fsck.ext3 /dev/fd0
范例2: 检测磁盘并显示时序信息
[root@linux test]# fsck.ext3 -ft /dev/fd0
2.2 服务器maint_samba使用fsck.ext3对文件系统进行修复过程
2.2.1查看fsck报错的日志
fileserver:~# ls -l /var/log/fsck/
total 8
-rw-r----- 1 root adm 190 2011-06-09 10:03 checkfs
-rw-r----- 1 root adm 192 2011-06-09 10:03 checkroot
这两个文件中会出现fsck的报错信息。
fileserver:~# more /var/log/fsck/checkfs
fileserver:~# more /var/log/fsck/checkroot
2.2.2查看当前的运行级别:
fsck.ext3扫描文件系统时一定要在单用户模式、修复模式或把设备umount后进行。如果扫描运行中的系统,会造成系统文件损坏。
选择在单用户模式下运行
# runlevel ---查看运行级别
fileserver:~# runlevel
N 2
#init 1 --单用户模式(1 S),在转换成单用户模式时可能会需要输入root密码。
fileserver:~# init 1
2.2.3使用fsck.ext3对文件系统进行扫描、修复
fileserver:~# fsck.ext3 -y /dev/sdb1 ---开始进入扫描、修正文件系统
注意红色方框,该位置需要输入yes
fsck.ext3开始进入扫描、修正文件系统,这个过程时间比较长,中间有数次停顿的过程,只需等待即可,千万不要以为死机而重启服务器。
fsck.ext3扫描、修正完文件系统后,根据提示可能需要重启系统。如果没有提示重启系统,也需要reboot来重启系统。
fileserver:~# reboot ---重启系统
在重启系统的过程中,fsck会对文件系统进行扫描,如下:
fsck扫描完以后,会启动到系统的登录界面,不需要进行任何干涉。
再次重新启动系统,系统可以正常启动。
至此服务器maint_samba使用fsck修复文件系统完成。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
CentOS修改eth0网卡的名字
当虚拟机复制粘贴后,网卡名,就变成了ens33这个网卡名称了,所以想改成eth0的网卡名称,主要步骤有1、新建网卡配置脚本(ifcfg-eth0)2、修改grub 3、重新建立grub 4、重启网卡,虽然在这过程中,可能还会遇到网卡没有网的情况,那就菊花疼了 复制虚拟机后的网卡名称 网卡名称需要修改为eth0格式的 修改网卡脚本 到网卡配置目录,我看到了,我的 网卡配置脚本是ifcfg-ens33,原来的配置文件的网卡 的脚本, cd /etc/sysconfig/network-scripts/ ls #查看网卡配置的脚本 DEVICE和NAME还是以前的,需要修改为我们该成的网卡eth0,如果更改不了文件,需要切换为管理员,然后打开文件 su root 复制网卡文件到ifcfg-eth0 复制网卡配置文件 #移动操作 mv /etc/sysconfig/network-scripts/ifcfg-enp0s3 /etc/sysconfig/network-scripts/ifcfg-eth0 #复制 cp /etc/sysconfig/network-scrip...
- 下一篇
Linux用户配置sudo权限
sudo的工作过程如下: 1,当用户执行sudo时,系统会主动寻找/etc/sudoers文件,判断该用户是否有执行sudo的权限 2,确认用户具有可执行sudo的权限后,让用户输入用户自己的密码确认 3,若密码输入成功,则开始执行sudo后续的命令 4,root执行sudo时不需要输入密码(eudoers文件中有配置root ALL=(ALL) ALL这样一条规则) 5,若欲切换的身份与执行者的身份相同,也不需要输入密码 visudo使用vi打开/etc/sudoers文件,但是在保存退出时,visudo会检查内部语法,避免用户输入错误信息 visudo需要root权限 [plain]view plain copy [hadoop@localhost~]$visudo visudo:/etc/sudoers:权限不够 visudo:/etc/sudoers:权限不够 使用visudo命令打开sudo配置文件 [plain]view plain copy ##Sudoersallowsparticularuserstorunvariouscommandsas ##therootu...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- SpringBoot2全家桶,快速入门学习开发网站教程
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Windows10,CentOS7,CentOS8安装Nodejs环境
- MySQL8.0.19开启GTID主从同步CentOS8
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装