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

实验: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

相关推荐

  • shell脚本参数练习

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登陆shell(即用户的shell不是/sbin/nologin),分别这两类用户的个数;通过字符串比较来实现; !/bin/bash # login_user=0 nologin_user=0 for i in $(cat /etc/passwd | cut -d : -f 7);do if [ $…

    2017-09-17
  • keepalived高可用haproxy配合varnish实现wordpress的动静分离

    haproxy和nginx都可以作为七层和四层反代服务器对外提供服务,此文通过haproxy和keealived配置varnish搭建wordpress的动静分离站点 一、实验环境 五台虚拟机: haproxy-1:搭建haproxy和keepalived服务,ip地址:192.168.11.176 haproxy-2:搭建haproxy和keepalive…

    2017-07-03
  • 修复引导启动

    修复MBR 备份MBR: dd if=/dev/sda of=/root/mbr.bak  bs=1  count=512  破坏 dd if=/dev/zero of=/dev/sda  bs=1 count=446 这里只要小于等于446即可。 借助安装光盘修复 装入光盘,在光盘引导界面选择 然后全部默认进入救援命令界面 切换根目录 使用grub-ins…

    2017-12-24
  • 马哥教育网络班21期+第7周课程练习

    1、创建一个10G分区,并格式为ext4文件系统; (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl; [root@localhost ~]# fdisk /dev/sda WARNING: DOS-compatible mode is&n…

    Linux干货 2016-08-24
  • 7月19号:计算机基础+在VMware12中安装CentOS6.8

        16号从正下暴雨的武汉来到帝都参加马哥培训班,从清河公寓亮哥开始,到宿舍另外五位室友,渐渐认识更多人,还算适应额不错。但走在北京的马路上,多少还是有些陌生,不过就如宿舍一样,来的时候脏兮兮,经过一番打扫后,干净了不少,我也会很快习惯在这边的生活,精力全放在linux上!   &nb…

    Linux干货 2016-08-05
  • 第十九周作业

    1.描述tomcat的架构 tomcat服务器是一种Servlet/jsp容器,更实质性的说是Servlet容器,因为jsp最终还是被编译成servlet来执行的。而对于servlet来说,其最长见的用途是扩展java web服务器功能,为来自web客户的请求提供服务。它完全运行在java虚拟机上。由于它的运行在服务器端,因此他的运行不依赖于浏览器。 tom…

    2017-07-11