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

实验: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)
ss
上一篇 2017-05-14
下一篇 2017-05-14

相关推荐

  • 【典韦文章】zabbix实现微信报警

    作者 典韦,追马代发 一、注册微信公众号 首先申请微信公众平台https://mp.weixin.qq.com/一个人最多申请5个公众号,所以还是可以的 申请完之后就可以根据腾讯的提示使用微信公众号了,然后用你自己的微信扫描关注微信号。 就可以看到用户数了,接下来的就要使用的用户的微信ID号了。点击用户查看用户的微信ID号。在浏览器查看用户的微信ID号。就是…

    Linux干货 2015-08-24
  • 三台服务器配置lamp

                   关于用三台服务器配置lamp 要求:(1) 三者分离于三台主机;          (2) 一个虚拟主机用于提供phpMyAdmin         &nbsp…

    2017-06-04
  • 把编译安装的httpd 实现服务脚本,通过service和chkconfig 进行管理

    把编译安装的httpd 实现服务脚本,通过service和chkconfig 进行管理 1 编译安装httpd 把httpd编译安装在/app/httpd/目录下。 2 在/etc/rc.d/init.d/目录下新建一个文件httpd 这个文件的目的在于让service 命令可以管理编译安装的httpd服务。 文件内容如下: [root@CentOS68 ~…

    Linux干货 2017-05-15
  • 设计模式(九)外观模式Facade(结构型)

    1. 概述      外观模式,我们通过外观的包装,使应用程序只能看到外观对象,而不会看到具体的细节对象,这样无疑会降低应用程序的复杂度,并且提高了程序的可维护性。例子1:一个电源总开关可以控制四盏灯、一个风扇、一台空调和一台电视机的启动和关闭。该电源总开关可以同时控制上述所有电器设备,电源总开关即为该系统的外观模式设计。 2.…

    Linux干货 2015-07-06
  • 树 非线性结构 树是n(n >= 0)个元素的集合: (1)每个元素称为结点(node); (2)有一个特定的结点,称为根结点或根(root); (3)除根结点外,其余结点被分成m(m>=0)个互不相交的有限集合,而每个子集又都是一棵树(称为原树的子树Subtree) 注意 n = 0时,称为空树 树只有一个特殊的没有前驱的元素,称为树的根(Ro…

    2017-10-16
  • 初学Linux之标准 I/O 和管道

    前面我们已经了解了文件系统的部分内容,我们可以通过 ls 命令让当前目录下的内容都显示在屏幕上,也可以使用 pwd 命令,显示当前的所在的目录路径。但是我们输入的是命令,本身并没有输入“显示”这类命令和要求,但是系统就自动的在屏幕上输出我们命令指定的信息。由此可以想象到,系统自身有默认的一种输出方式,同时,有输出就有输入,当输入的和系统无关,系统也会自动提示错误,以上就是我们接下来要了解的基础内容——标准 I/O。具体的涉及内容包括:三种 I/O 设备,把 I/O 重定向入文件,tr 命令的使用,使用管道链接命令。

    2017-12-02