马哥教育网络班21期+第10周课程练习

1、请详细描述CentOS系统的启动流程(详细到每个过程系统做了哪些事情)

    1)开机后会进行POST(开机加电自检),加载BIOS,之后会根据BIOS上的boot  sequence(引导加载次序)找到第一个有引导程序的设备,找到MBR,bootloader(引导加载器)就安装在MBR内。MBR组成部分(bootloader--446字节,fat(文件系统分配表)--64字节,有效标记--2字节)
    2)Linux的bootloader是grub。作用是允许用户选择内核,将内核加载到内存的特定空间中,解压,展开之后,把系统控制权交给内核。
    3)内核进行自身初始化工作。探测可识别的所有硬件设备,加载硬件驱动程序(会借助ramdisk(centos 6 ramfs)加载驱动),并以只读方式挂载根文件系统。运行用户空间的第一个应用程序(/sbin/init)
    4)/sbin/init 应用程序会根据/etc/inittab里的配置,运行系统初始脚本,完成系统初始化,关闭或启动对应级别下的服务,启动终端。

2、为运行于虚拟机上的CentOS 6添加一块新硬件,提供两个主分区;

blob.png

(1) 为硬盘新建两个主分区;并为其安装grub;
在 /mnt 下新建目录boot ,执行以下命令

blob.png

cd /mnt/boot/,查看执行结果

blob.png

(2) 为硬盘的第一个主分区提供内核和ramdisk文件; 为第二个分区提供rootfs;
cp /boot/vmlinuz-2.6.32-431.el6.x86_64 /mnt/boot/vmlinuz-2.6.32-431.el6.x86_64cp /boot/initramfs-2.6.32-431.el6.x86_64.img /mnt/boot/vmlinuz-2.6.32-431.el6.x86_64创建rootfs文件夹,挂载/dev/sdc2到此目录,创建系统所需目录
mkdir /mnt/rootfs     mount  /dev/sdc2 /mnt/rootfs
cd  /mnt/rootfs
mkdir  bin  boot  dev  etc  home  lib  lib64 media  misc  mnt  opt  proc  root  sbin  srv  sys  users  usr  var
(3) 为rootfs提供bash、ls、cat程序及所依赖的库文件;cp /bin/bash /mnt/roofs/bincp /bin/ls   /mnt/roofs/bincp /bin/ls /mnt/rootfs/binfor i in `ldd /bin/bash | grep -o "[^[:space:]]*/lib[^[:space:]]*"`; do cp $i /mnt/rootfs/lib64/ ; donefor i in `ldd /bin/ls| grep -o "[^[:space:]]*/lib[^[:space:]]*"`; do cp $i /mnt/rootfs/lib64/ ; donefor i in `ldd /bin/cat | grep -o "[^[:space:]]*/lib[^[:space:]]*"`; do cp $i /mnt/rootfs/lib64/ ; done
(4) 为grub提供配置文件;
vim /mnt/boo/grub/grub.confdefault=0timeout=5title CentOS (ljy)
    root (hd0,0)
    kernel /vmlinuz-2.6.32-431.el6.x86_64 ro root=/dev/sda2 selinux=0 init=/bin/bash
    initrd /initramfs-2.6.32-431.el6.x86_64.img
(5) 将新的硬盘设置为第一启动项并能够正常启动目标主机;

blob.png

blob.png

3、制作一个kickstart文件以及一个引导镜像。描述其过程。

一、制作ks 文件
安装system-config-kickstart
yum install -y system-config-kickstart-2.8.6.5-1.el6.noarch.rpm
运行system-config-kickstart

blob.png

打开一个ks文件。

blob.png

根据需要配置相关的内容。配置好后,将文件进行另存操作,起名叫myks.cfg。

二、创建引导镜像。

在/tmp 目录下创建目录myiso ,在myiso 目录下创建isolinux 目录。
执行cp /media/isolinux/* isolinux/  将光盘上的isolinux 下的文件都拷贝到新建的目录下。
将myks.cfg文件复制到/tmp/myiso 目录下。

blob.png

创建ISO文件系统
mkisofs -R -J -T -v --no-emul-boot --boot-load-size 4 --boot-info-table -V "CentOS 6.5 x86_64 boot" -b isolinux/isolinux.bin -c isolinux/boot.cat -o /root/boot.iso myiso
到/root 下查看。

4、写一个脚本
(1) 能接受四个参数:start, stop, restart, status
start: 输出“starting 脚本名 finished.”

(2) 其它任意参数,均报错退出;

    #!/bin/bash
    #
    case $1 in
        start)            echo "starting $0 finished."
    ;;
        stop)            echo "stopping $0 finished"
    ;;
        restart)            echo "restarting $0 finished"
    ;;
        status)            echo "status $0 finished"
    ;;
        *)            echo "error Usage: $0 start|stop|restart|status"
            exit 3
    ;;    esac

5、写一个脚本,判断给定的用户是否登录了当前系统;
(1) 如果登录了,则显示用户登录,脚本终止;
(2) 每3秒钟,查看一次用户是否登录;

#!/bin/bash#declare -a aadeclare -a bb
bb=`awk -F: '{print $1}' /etc/passwd | xargs`if echo ${bb[@]} | grep -w "$1" &>/dev/null ;thenwhile true;doaa=`who | cut -d" " -f1 |sort |uniq | xargs`        if echo ${aa[@]} | grep -w "$1" &>/dev/null ;then
        echo "$1 is longin" 
        exit
        fi
    echo "wait 3 second"
    sleep 3doneelse
    echo "$1 is not a user"fi

6、写一个脚本,显示用户选定要查看的信息;
cpu) display cpu info
mem) display memory info
disk) display disk info
quit) quit
非此四项选择,则提示错误,并要求用户重新选择,只到其给出正确的选择为止;

    #!/bin/bash
    #
    select a in "cpu" "mem" "disk" "quit";do
    case $a in
        cpu)
            cat /proc/cpuinfo
    ;;
        mem)
            cat /proc/meminfo
    ;;
        disk)
            df -h
    ;;
        quit)
            exit
    ;;
        *)
            echo "wrong args,select option 1) cpu 2) mem 3) disk 4) quit"   
    ;;
    esac
    done

7、写一个脚本
(1) 用函数实现返回一个用户的UID和SHELL;用户名通过参数传递而来;
(2) 提示用户输入一个用户名或输入“quit”退出;
当输入的是用户名,则调用函数显示用户信息;
当用户输入quit,则退出脚本;进一步地:显示键入的用户相关信息后,再次提醒输出用户名或quit:

    #!/bin/bash
    #
    declare -a aa
    aa=`awk -F: '{print $1}' /etc/passwd | xargs`    
    bb () {
    UId=`id -u $ss`    #SHELL=`awk -F: '$3 ~/\<"$UId"\>/{print $7}' /etc/passwd`
    #SHELL=`grep $UId /etc/passwd |cut -d: -f7`
    SHELL=`cut -d: -f1,3,7 /etc/passwd |grep "^\<$ss\>" |cut -d: -f3`    echo $UId 
    echo $SHELL
    }    while true;do
    read -p "please enter a username or quit:" ss    
    if echo ${aa[@]} | grep -w "$ss" &>/dev/null ;then
    echo $ss
    bb    elif [ $ss == "quit" ];then
        exit
    fi
    done

8、写一个脚本,完成如下功能(使用函数)
(1) 提示用户输入一个可执行命令的名字;获取此命令依赖的所有库文件;
(2) 复制命令文件至/mnt/sysroot目录下的对应的rootfs的路径上,例如,如果复制的文件原路径是/usr/bin/useradd,则复制到/mnt/sysroot/usr/bin/目录中;
(3) 复制此命令依赖的各库文件至/mnt/sysroot目录下的对应的rootfs的路径上;规则同上面命令相关的要求;

    #!/bin/bash
    #
    [ -d /mnt/sysroot ] || mkdir /mnt/sysroot 
    [ -d /mnt/sysroot/rootfs ] || mkdir /mnt/sysroot/rootfs
    [ -d /mnt/sysroot/usr/bin ] || mkdir -p /mnt/sysroot/usr/bin
    sysroot=/mnt/sysroot
    rootfs=/mnt/sysroot/rootfs
    sysbin=/mnt/sysroot/usr/bin    read -p "please enter a command:" cmd
    
    cmddir=`which $cmd | tail -1`    cmlib () {    
    echo "依赖库展示"
    ldd $cmddir
    
    }    cmdcp () {    echo "命令复制,查看路径:$sysbin,$rootfs"
    if [ "$cmddir" == "/usr/sbin/useradd" ] ;then
    cp $cmddir $sysbin
    else 
    cp $cmddir $rootfs
    fi
    }    cmlibcp () {    echo "库文件复制"
    ldd $cmddir > /tmp/$$.ldd.txt
    libname=`cat /tmp/$$.ldd.txt |sed 's/(.*)//g'| sed 's/[[:space:]]//g' |sed 's/.*=>//' | sed '1d' |xargs`    for i in $libname;do
        if [ "$cmddir" == "/usr/sbin/useradd" ] ;then
        cp $i $sysbin
        else
        cp $i $rootfs
        fi
    done
    }    
    #cmlib
    #cmdcp
    cmlibcp

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

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-19 17:27

    写的很棒,如果脚本在调整一下格式的话,会更好