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

相关推荐

  • N28-第三周

    1. 列出當前系統上所有已經登入的用戶的用戶名,注意:同一個用戶登入多次,則只顯示一次即可。
    2. 取出最後登入到當前系統的用戶的相關信息。
    3. 取出當前系統上被用戶當做其默認shell的最多的那個shell。
    4. 將/etc/passwd中的第三個字段數值最大的後10個用戶的信息全部改為大寫後保存至/tmp/maxusers.txt文件中。
    5. 取出當前主機的IP地址,提示:對ifconfig命令的結果進行切分。
    6. 列出/etc目錄下所有以.conf結尾的文件的文件名,並將其名字轉換為大寫後保存至/tmp/etc.conf文件中。
    7. 顯示/var目錄下一級子目錄或文件的總各數。
    8. 取出/etc/group文件中第三個字段數值最小的10個組的名字。
    9. 將/etc/fstab和/etc/issue文件的內容合併為同一個內容後保存至/tmp/etc.test文件中。
    10. 請總結描述用戶和組管理類命令的使用方法並完成以下練習:
    (1) 創建組distro,其GID為2016。
    (2) 創建用戶mandriva,其ID號為1005,基本組為distro。
    (3) 創建用戶mageia,其ID號為1100,家目錄為/home/linux。
    (4) 給用戶mageia添加密碼,密碼為mageedu。
    (5) 刪除mandriva,但保留其家目錄。
    (6) 創建用戶slackware,其ID號為2002,基本組為distro,附加組peguin。
    (7) 修改slackware的默認shell為/bin/tcsh。
    (8) 為用戶slackware新增附加組admins。

    2017-12-19
  • shell 脚本 【上】

    shell 脚本编程 【上】 程序就是指令加上数据组合而成 程序编程风格:  过程式:以指令为中心,数据服务于指令  象式:以数据为中心,指令服务于数据  编程语言:  低级:汇编  高级:  编译:高级语言–>编译器–>目标代码 java,C#  解释…

    Linux干货 2016-08-15
  • Linux Basic–磁盘分区

    附件: 磁盘管理相关方法.pdf

    Linux干货 2016-11-21
  • 网络第21期第七周作业

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

    Linux干货 2016-10-09
  • 编译安装LAMP及分离式LAMP平台构建

    前言 LAMP网站架构是目前国际流行的Web框架,该框架包括:Linux操作系统,Apache网站服务器,MySQL数据库,Perl、PHP或者Python编程语言,所有组成产品均是开源软件,是国际上成熟的架构框架,很多流行的商业应用都是采取这个架构,和Java/J2EE架构相比,LAMP具有Web资源丰富、轻量、快速开发等特点,与微软的.NET架构相比,L…

    Linux干货 2015-04-20
  • vim编辑器的常见使用

    1、vim介绍 Vim是从 vi 发展出来的一个文本编辑器,处理文本文件功能强大。 三种主要模式: Vim打开文件,默认命令(Normal)模式,可以移动光标,剪切和粘贴。 按键i 进入插入(Insert)模式,用户可以编辑文本。 扩展(Extended)命令模式(或末行模式)用户:wq可保存退出,或者:q!强制退出。 Exc按键可退出当前模式。 2、文本操…

    Linux干货 2017-07-30

评论列表(1条)

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

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