马哥教育网络班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)
上一篇 2016-09-19 13:47
下一篇 2016-09-19 13:48

相关推荐

  • 8月3日课堂笔记

    课堂笔记 linux用户和组管理(非常非常重要)    用户管理和组管理各种相关的应用程序    简单的管理命令 安全上下文:   每次对主机操作都是以发起一个进程来完成的,进程代表着人来执行操作,进程以其发起者的身份来运行;所以开机时有很多守护类的进程,我们应该以普通身份来运行,普通用户通常都是系统用户;从来不用登陆系统的;进程对文件的访问权限,取决于发起…

    Linux干货 2016-08-04
  • N26-第四周作业-邢岩

    马哥门徒-N26-邢岩   精神练习需要深入认真的工作以及热情的劲头。当你开始练习,你是在挣扎、在反抗,你需要集中精力,然后慢慢进步。那么,我们就开始吧。   第一题,复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。   ~]# cp -r /et…

    Linux干货 2017-02-15
  • wordpress配置安装

    1、首先进行lamp框架的搭建 服务器环境:Linux Centos 7.2.1511 64位 内存:2G  磁盘空间100GB IP地址:10.55.10.79 进行httpd,php,php-mysql,mariadb-server的安装,安装均使用yum安装 ~]# yum -y install httpd php php-mysql mar…

    Linux干货 2016-11-04
  • Python语法基础之if while for常见的简单算法

    格式要符合语法要求

    2017-09-14
  • 硬链接与软链接的区别

    硬链接(Hard Link):   硬连接指通过索引节点来进行链接(即一个指针指向文件索引节点)。在Linux的文件系统中,保存在磁盘分区中的文件不管是什么类型都给它分配一个编号,称为索引节点号(Inode Index)。在Linux中,多个文件名指向同一索引节点是存在的。一般这种链接就是硬链接。硬链接的作用是允许一个文件拥有多个有效路径…

    Linux干货 2016-10-20
  • 学习宣言

    此刻打盹,你将做梦,此刻学习,你将圆梦! 为了财富自由,前进!

    Linux干货 2016-12-28

评论列表(1条)

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

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