> 技术文档 > Linux 系统启动原理2

Linux 系统启动原理2


/etc/fstab 引起的系统启动问题

环境准备

 #这就像给新硬盘创建 \"分区表\",相当于给一本书设计目录结构 #\"msdos\" 是传统的分区表格式,告诉系统如何管理这个硬盘的分区 [root@server ~ 09:53:33]# parted /dev/sdb mklabel msdos 信息: You may need to update /etc/fstab. ​ #在硬盘上划出一块 \"土地\" 作为主要分区 #\"unit MiB\" 表示用兆字节做单位 #\"1 10241\" 意思是从第 1MB 开始,到 10241MB 结束(大约 10GB) 系统提示可能需要更新 fstab,就像提醒你 \"记得把新房间信息登记到住址本上\" [root@server ~ 09:55:49# parted /dev/sdb unit MiB mkpart primary 1 10241信息: You may need to update /etc/fstab. ​ #想在刚划分的分区上创建 xfs 文件系统(相当于给新房间铺地板) #但系统提示:这个分区已经有 swap 文件系统了(像发现房间里已经铺了地毯) #建议用 - f 参数强制覆盖(相当于 \"确定要拆掉现有地毯换新地板吗?\") [root@server ~ 09:55:57]# mkfs.xfs /dev/sdb1 mkfs.xfs: /dev/sdb1 appears to contain an existing filesystem (swap). mkfs.xfs: Use the -f option to force overwrite. ​ #在系统里创建一个叫 /data01 的 \"入口\"(相当于给新房间装个门牌号) [root@server ~ 09:56:32]# mkdir /data01 ​ #把这个新分区的信息写入系统配置文件(相当于在住址本上登记新房间信息) #这样系统启动时就知道该怎么找到并使用这个分区了 [root@server ~ 09:57:08]# echo \'/dev/sdb1 /data01 xfs defaults 0 0\' >> /etc/fstab ​ #让系统按照 fstab 里的配置挂载所有分区(相当于 \"按住址本信息找到所有房间并打开门\") #第一次失败了,因为分区还是 swap 格式,和我们登记的 xfs 格式不匹配(地毯和地板不兼容) [root@server ~ 09:58:00]# mount -a mount: 文件系统类型错误、选项错误、/dev/sdb1 上有坏超级块、        缺少代码页或助手程序,或其他错误 ​ #加 - f 参数强制把分区格式化成 xfs(终于下定决心拆掉地毯,铺上我们要的地板) [root@server ~ 10:01:22]# mkfs.xfs -f /dev/sdb1 ​ #再次尝试挂载所有分区,这次系统提示 \"/dev/sdb1 已经挂载或 /data01 忙\" #其实是已经挂载成功了,只是提示信息有点迷惑人(相当于 \"门已经打开了,你已经在房间里了\") [root@server ~ 10:01:45]# mount -a mount: /dev/sdb1 已经挂载或 /data01 忙 ​ [root@server ~ 10:02:01]# df -h /data01 文件系统       容量 已用 可用 已用% 挂载点 /dev/sdb1       10G   33M   10G    1% /data01 ​

故障1:挂载点不存在

准备环境
 [root@server ~ 10:02:11]# umount /data01 [root@server ~ 10:11:36]# rmdir /data01
重启验证
 #依然正常进入系统 [root@server ~ 10:11:42]# reboot #挂载点自动创建 [root@server ~ 10:14:13]# df -h /data01 文件系统       容量 已用 可用 已用% 挂载点 /dev/sdb1       10G   33M   10G    1% /data01

故障2:设备名称写错或者找不到设备

 [root@server ~ 10:14:51]# vim /etc/fstab #进入vim修改 /dev/sdb2 /data01 xfs defaults 0 0 ​ #发现进入不了系统 ​ #重启按e进入编辑,空格第二行utf-8 输入rd.break  ​ #switch_root:/# mount -o remount,rw /sysroot ​ #switch_root:vi /sysroot/etc/fstab 进入注释掉错误命令后可以进入系统,或者直接修改错误也可进入系统 #退出保存   exit

故障3:破坏文件系统

准备故障
 [root@server ~ 10:35:05]# dd if=/dev/zero of=/dev/sdb1 bs=1M count=1 记录了1+0 的读入 记录了1+0 的写出 1048576字节(1.0 MB)已复制,0.00152951 秒,686 MB/秒 #重启发现进入不了系统 [root@server ~ 10:42:53]# reboot
 #看提示查找日志 执行:journalctl -p err ​ #改英文看信息 unset LANG mount /data01 ​ #输入密码(123)进入命令行,执行备份恢复 [root@server ~ 10:44:56]# xfs_repair /dev/sdb1 ​ #退出保存 exit

grub2 配置

grub 菜单超时时间

 root@server ~ 10:59:59]# vim /etc/default/grub # 修改GRUB_TIMEOUT为15 GRUB_TIMEOUT=15 ​ # 生效grub2.cfg配置文件 ​ # 重启 后有15秒倒计时 [root@centos7 ~]# reboot

kernel 启动参数

 [root@server ~ 11:19:16]# vim /etc/default/grub ​ #vim编辑设置重启不显示启动过程,启动进程显示到ttys0上,看不见 GRUB_CMDLINE_LINUX=\"rd.lvm.lv=centos/root rd.lvm.lv=centos/swap rhgb quiet console=ttys0\" ​ # 生成grub2.cfg配置文件,重启验证 [root@server ~ 11:20:42]# grub2-mkconfig -o /etc/grub2.cfg ​ #重启不显示启动过程,开机黑色 [root@server ~ 11:21:19]# reboot ​

grub 菜单加密

# 查看/etc/grub.d/01_users脚本[root@server ~ 11:36:25]# cat /etc/grub.d/01_users#!/bin/sh -ecat << EOFif [ -f \\${prefix}/user.cfg ]; then source \\${prefix}/user.cfg if [ -n \"\\${GRUB2_PASSWORD}\" ]; then set superusers=\"root\" export superusers password_pbkdf2 root \\${GRUB2_PASSWORD} fifiEOF# 生成grub2密码[root@server ~ 11:37:07]# grub2-mkpasswd-pbkdf2输入口令:Reenter password:#复制is之后的字符段grub.pbkdf2.sha512.10000.24B84F0390065EF3B1E98C5B611D57DEFB357B140F51A99CCBA9F99947B09F9DE463A4F41721193B470BFC26482F59A3E6A9286110BBC8C910AEA9F2314EC723.AB1DF877EEFE1FE0EC07B2E351DB70EE151B8B2CAE3D791804777DA2EB26EB0DA47FB9702E92F26669887D492BA7B240F857B08067053D6EE4FAB47A71CFA6F2#创建加密文件[root@server ~ 11:37:42]# vim /boot/grub2/user.cfg#vim写入GRUB2_PASSWORD=grub.pbkdf2.sha512.10000.24B84F0390065EF3B1E98C5B611D57DEFB357B140F51A99CCBA9F99947B09F9DE463A4F41721193B470BFC26482F59A3E6A9286110BBC8C910AEA9F2314EC723.AB1DF877EEFE1FE0EC07B2E351DB70EE151B8B2CAE3D791804777DA2EB26EB0DA47FB9702E92F26669887D492BA7B240F857B08067053D6EE4FAB47A71CFA6F2# 生成grub2.cfg配置文件,重启验证[root@server ~ 11:39:15]# reboot#重启,按e进入需要密码,不能像之前直接进入修改