实验:系统启动和内核管理

实验:bootloader

  • 破坏stage1:

    • 备份:dd if=/dev/sda of=/app/mbr bs=1 count=512
    • 破坏:dd if=/dev/zero of=/dev/sda bs=1 count=446;此时/boot/grub/下的文件没有任何改动;
    • 表现:stage1破坏后系统会直接进行光盘引导
    • 修复1:救援模式–>使用自己备份的前446个字节或使用/boot/grub/stage1恢复;如果恢复不了,使用grub-install –root-directory=/ /dev/DISK
    • 修复2:

      1. grub(hd0,0)
      2. setup(hd0)
  • 破坏stage1.5:

    • 破坏:dd if=/dev/zero of=/dev/sda bs=1 count=2048 skip=512 seek=512
    • 表现:跳过光盘引导,菜单不显示,说明破坏成功;
    • 修复:使用grub

      1. grub>root (hd0,0)
      2. grub>setup (hd0)
  • 破坏stage2:

    • 破坏:把/boot/grub/下的所有文件都移除;
    • 修复:使用grub-install /dev/sda

      1. 修复完成后/boot/grub/中的文件会恢复,grub.conf不会恢复;要么copy、要么手写一份;

grub加口令

grub-md5-crypt 生成MD5口令
  使用格式:password --md5 $1XXXXX

  grub-crypt  生成sha512口令
  使用格式:password --encrypted xxxxx

编辑:/boot/grub/grub.conf

default=0  (默认title,从0开始)
    timeout=5 (启动时的倒计时)
    splashimage=(hd0,0)/grub/splash.xpm.gz  (转化png :yum searrch ImageMagick)
    hiddenmenu  (隐藏菜单)
    password --md5 生成的口令 or password --encrypted 生成的口令
    title CentOS 6 (2.6.32-642.el6.x86_64)
            root (hd0,0)
            kernel /vmlinuz-2.6.32-642.el6.x86_64 ro root=UUID=472a74aa-d91e-4b79-844b-90415bdfb7c8 rd_NO_LUKS rd_NO_LVM LANG=en_US.UTF-8 rd_NO_MD SYSFONT=latarcyrheb-sun16 crashkernel=auto  KEYBOARDTYPE=pc KEYTABLE=us rd_NO_DM rhgb quiet
                (rhgb:没有启动图形界面)
                (quiet:不显示启动过程)
            initrd /initramfs-2.6.32-642.el6.x86_64.img
            password magedu

删除/boot/grub/grub.conf,恢复

  1. 启动后进入grub命令行模式,手动引导启动
  2. kernel /vmlinuz-2.6.32-642.el6.x86_64 支持tab键补全
  3. initrd /initramfs-2.6.32-642.el6.x86_64.img
  4. boot
  5. 重新进入系统后再进行grub.conf的修改

删除/boot/grub/*,恢复

grub界面不能出现,只能进入救援模式修复

  1. 必须切换根,grub-install,只有在切根后才能使用;此时,grub命令行不能修复;
  2. 敲几遍sync
  3. 编写grub.conf

    • title
    • kernel
    • initrd
  4. 启动

删除/boot/ 所有内容,恢复

1)/boot/vmlinuz
  cp /mnt/cdrom/isolinux/vmlinuz /boot/vmlinuz-`uname -r`

  2)/boot/initramfs.img
  mkinitrd /boot/initramfs-`uname -r`.img `uname -r`

  或:
  rpm -ivh /mnt/cdrom/Packages/kernel.XXX.rpm 

  3)grub/*
  grub-install /dev/sda

  4)grub/grub.conf
  default=0
  timeout=3
  title 23M
  kernel /vmlinuz-XXXX root=/dev/sda2
  initrd /initramfs-XXXX.img

在普通分区,删除/boot/ 所有内容及/etc/fstab,恢复

1)救援模式,先恢复/etc/fastab
  df
  blkid 
  mount /dev/sda1 /mnt/sda1
  mount /dev/sda2 /mnt/sda2
  mount /dev/sda3 /mnt/sda3

  vim /etc/fstab
  UUID=41ccbfcf-fa37-48dd-b841-2f3dd6b2d47a /boot  ext4 defaults 0 0 
  UUID=472a74aa-d91e-4b79-844b-90415bdfb7c8 /      ext4 defaults 0 0 
  UUID=4db8e7e8-0652-4162-95cc-aa223cb2e393 /apps  ext4 defaults 0 0 
  UUID=5beb6ff8-3e37-42a0-9413-013aeacbfa8b  swap   swap   deafaults 0 0

  在创建/etc/fstab时,出现了fstab文件是个只读模式;此时,在切根前进行重新挂载,mount -o remount,rw /

  2)reboot,重新进入救援模式
  df 确保挂载成功

  3)修复grub
  grub-install /dev/sda

  4)修复kernel initramfs.img
  mount /dev/sr0 /mnt/
  rpm -ivh /mnt/Packages/kernel-XXX.rpm --force

  5)vim /boot/grub/grub.conf
    default=0
    timeout=3
    title centos 6
    kernel /vmlinuz-2.6.32-642.el6.x86_64  root=/dev/sda2
    initrd /initramfs-2.6.32-642.el6.x86_64.img

使用逻辑卷,删除/boot/ 所有内容及/etc/fstab,恢复

1)救援模式,先/etc/fastab恢复
  df
  blkid 
  mount /dev/sda1 /mnt/sda1
  lvdisplay
  vgchange -ay 激活卷组
  lvdisplay 查看逻辑卷
  ls /dev/mapper :可查看设备可用

  先挂载root创建/root/etc/fstab
  vim /etc/fstab
    UUID=ccbd4c46-b1a2-41da-aac7-d3a45a688b38 /boot  ext4 defaults 0 0 
    /dev/mapper/vg0-root / ext4 defaults 0 0
    /dev/mapper/vg0-swap swap swap defaults 0 0  
    /dev/mapper/vg0-usr /usr ext4 defaults 0 0
    /dev/mapper/vg0-var /var ext4 defaults 0 0

  在创建/etc/fstab时,出现了fstab文件是个只读模式;此时,在切根前进行重新挂载,mount -o remount,rw /

  2)reboot,重新进入救援模式
  df 确保挂载成功

  3)修复grub
  grub-install /dev/sda
  sync

  4)修复kernel initramfs.img
  mount /dev/sr0 /mnt/
  rpm -ivh /mnt/Packages/kernel-XXX.rpm --force

  5)vim /boot/grub/grub.conf
    default=0
    timeout=3
    title centos 6.8 test
    kernel /vmlinuz-2.6.32-642.el6.x86_64 root=/dev/mapper/vg0-root
    initrd /initramfs-2.6.32-642.el6.x86_64.img

自制Linux

  • 安装一块干净的硬盘
    echo ‘- – -‘ > /sys/class/scsi_host/host2/scan

  • 分区并创建文件系统
    fdisk /dev/sdb
    分两个必要的分区
    /dev/sdb1对应/boot /dev/sdb2对应根 /
    mkfs.ext4 /dev/sdb1
    mkfs.ext4 /dev/sdb2

  • 挂载boot
    mkdir /mnt/boot 子目录必须为boot
    mount /dev/sdb1 /mnt/boot

  • 挂载root
    mkdir /mnt/root
    mount /dev/sdb2 /mnt/root

  • 安装grub
    grub-install –root-directory=/mnt /dev/sdb

  • 恢复内核和initramfs文件
    cp /boot/vmlinuz-2.6.32-642.el6.x86_64 /mnt/boot/
    cp /boot/initramfs-2.6.32-642.el6.x86_64.img /mnt/boot

  • 建立grub.conf:
    vim /mnt/boot/grub.conf

    title newlinux
    root (hd0,0)
    kernel /vmlinuz-2.6.32-642.el6.x86_64 root=/dev/sda2 (如要精确表示使用根分区的UUID)selinux=0 init=/bin/bash
    initrd /initramfs-2.6.32-642.el6.x86_64.img
  • chroot /mnt/sysroot

  • 创建一级目录
    mkdir –pv /mnt/sysroot/{etc,lib,lib64,bin,sbin,tmp,var,usr,sys,proc,opt,home,root,boot,dev,mnt,media}

  • 复制bash和相关库文件

  • 复制相关命令及相关库文件
    如:ls,cat,vim,reboot,hostname等

原创文章,作者:s,如若转载,请注明出处:http://www.178linux.com/75512

(0)
上一篇 2017-05-14 09:03
下一篇 2017-05-14 11:20

相关推荐

  • 初识shell脚本编程

    shell脚本基础 shell脚本是包含一些命令或声明,并符合一定格式的文本文件 一般格式要求: 1.首行shebang机制 #!/bin/bash #!/bin/python #!/usr/bin/perl 2.注释信息 以#开头,可写明脚本用途,作者,版本,时间等 3.脚本正文内容, 创建shell脚本 以bash为例 第一行定格#!/bin/bash …

    Linux干货 2016-08-15
  • N24期第四周作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 2、编辑/etc/group文件,添加组hadoop。 vim /etc/group,增加此行 3、手动编辑/etc/passwd文件新增一行,添加用户hadoop,其基本组ID为hadoop组的id号;其家目录为/home…

    Linux干货 2016-11-22
  • Shell脚本编程

    Shell脚本编程

    2017-09-20
  • 网络管理3

    七、网络接口配置-bonding     Bonding         就是将多块网卡绑定同一IP地址对外提供服务,可以实现高可用或者负载均衡。当然,直接给两块网卡设置同一IP地址是不可能的。通过bonding,虚拟一块网卡对外提供连接,…

    Linux干货 2016-09-10
  • find 详解

    find 命令基本用法:         find pathname [opotions] [-print | -exec | -ok …] 1、find 基本参数:         pa…

    Linux干货 2016-12-26
  • grep是个什么鬼

    正则表达式   一个正则表达式是一个描述了一个字符串集合的模式。正则表达式的构造类似于算术表达式,使用各种各样的操作符来将更小的表达式连在一起。 Grep能理解两种不同版本的正则表达式语法:“basic”和“extended”。在GNU grep中,两种语法可以实现的功能是没有区别的。在其他实现中,基本(basic)正则表达式表达能力要弱一点。下面…

    Linux干货 2017-04-17