马哥教育网络班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

(0)
hhaa0352hhaa0352
上一篇 2016-09-19 13:47
下一篇 2016-09-19 13:47

相关推荐

  • linux下小练习(2)

    1、编写脚本/bin/per.sh,判断当前用户对指定的参数文件,  是否不可读并且不可写                         2、编写脚本/root/bin/nologin.sh和login.sh,实现禁止和充 许…

    Linux干货 2016-08-15
  • 文本处理三剑客之grep

    grep命令基本用法 1、grep正则表达式(对文本行进行搜索过滤) 格式:grep [option] PATTERN [FILE…] option: -i:忽略大小写 -v:取反,显示未被匹配到的pattern -n:显示匹配的行号 -c:统计匹配的行数 -o: 只显示匹配到的pattern -q: 静默,不予显示 -A#:after,匹配到的行再向后…

    Linux干货 2017-07-19
  • 文件查找(find)

                                  …

    2017-04-11
  • 回溯法 -数据结构与算法

    1.回溯法算法思想: 定义:         回溯法(探索与回溯法)是一种选优搜索法,按选优条件向前搜索,以达到目标。但当探索到某一步时,发现原先选择并不优或达不到目标,就退回一步重新选择,这种走不通就退回再走的技术为回溯法,而满足回溯条件的某个状态的点称为“回溯点”。 1、回溯法适用:有许多问题,当需要找出它的解集(…

    Linux干货 2015-04-07
  • scp和rsync的使用

    通过一些简单需求了解scp和rsync的使用

    2017-09-18
  • vsftpd基于mysql实现用户认证

    一、前言   ftp介绍:     ftp全程是File Transfer Protocol(文件传输协议),方便于实文件交换;但是在文件传输以及账号密码发送时都是以明文传输,因此是一个明文协议 ftp是C/S方式:   常见的客户端有:     GUI方式:browers、FileZilla-cl…

    Linux干货 2015-06-15

评论列表(1条)

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

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