N22-第十周作业

第十周    
1、请详细描述CentOS系统的启动流程(详细到每个过程系统做了哪些事情)
    POST–>BootSequence(BOIS)–>BootLoader(MBR)–>Kernel(ramfs或者ramdisk)–>rootfs–>rootfsswitch–>/sbin/init–>/etc/inittab,/etc/init/*.conf–>设定默认运行的级别–>系统初始化脚本–>关闭和开启对应级别下的服务–>启动终端
    POST:检测硬件设备,包括硬盘内存等等
    BootSequence:主要是设定BIOS的启动顺序。
    BootLoader:根据BIOS设定的启动顺序去加载启动文件,位于磁盘中的MBR部分
    Kernel:把ram空间当成磁盘空间使用,形成一个小的rootfs,然后去加载内核文件
    rootfs:加载真正的根文件系统
    rootswitch:完成两个根的转换。
    /sbin/init:执行第一个用户空间程序,这个程序会引导以后的用户空间的初始化过程
    /etc/inittab,/etc/init/*.conf:加载init级别加载/etc/init/*.conf 这些配置文件。
    设定默认运行的级别:根据加载的inittab文件设定的init级别去定义init级别
    系统初始化脚本:
    关闭和开启对应级别下的服务:开启和关闭当前init级别下的服务信息
    启动终端:启动终端
    
2、为运行于虚拟机上的CentOS 6添加一块新硬件,提供两个主分区;
  (1) 为硬盘新建两个主分区;并为其安装grub;
  (2) 为硬盘的第一个主分区提供内核和ramdisk文件; 为第二个分区提供rootfs;
  (3) 为rootfs提供bash、ls、cat程序及所依赖的库文件;
  (4) 为grub提供配置文件;
  (5) 将新的硬盘设置为第一启动项并能够正常启动目标主机;
  # fdisk /dev/sdb
  # partx -a /dev/sdb
  # mount /dev/sdb1 /mnt/boot
  # mount /dev/sdb2 /mnt/sysroot
  # grub-install –root-directory=/mnt/sysroot /dev/sdb
  # cp /boot/vmlinuz-2.6.32-504.el6.x86_64 /mnt/boot/vmlinuz
  # cp /boot/initramfs-2.6.32-504.el6.x86_64.img /mnt/boot/initramfs.img
  # cp /boot/grub/grub.conf /mnt/boot/grub/grub.conf
  # vim /mnt/boot/grub/grub.conf
            default=0
            timeout=5
            hiddenmenu
            title CentOS 6 (test new)
            root (hd0,0)
            kernel /vmlinuz ro root=/dev/sda1 selinux=0 init=/bin/bash
            initrd /initramfs.img
  # mkdir -pv /mnt/sysroot/{bin,sbin,lib,lib64,etc,home,root,media,mnt,dev,tmp}
  # cp /bin/{bash,ls,cat} /mnt/bin
  # cp `ldd /bin/{bash,ls,cat}|grep -eo "/lib.*[[:space:]]"| sort -u` /mnt/lib
  # sync
  # init 6
  创建一个新的虚拟机挂载挂载新的硬盘然后启动。
3、制作一个kickstart文件以及一个引导镜像。描述其过程。
4、写一个脚本
  (1) 能接受四个参数:start, stop, restart, status
   start: 输出“starting 脚本名 finished.”
   …
  (2) 其它任意参数,均报错退出;
    #!/bin/bash
    #
    case $1 in
    start)
            echo "starting $0 finished."
            ;;
    stop)
            echo "stoping $0 finished."
            ;;
    restart)
            echo "restarting $0 finished."
            ;;
    status)
            echo "show $0 status."
            ;;
    *)
            echo "The para error"
            exit
    esac

5、写一个脚本,判断给定的用户是否登录了当前系统;
  (1) 如果登录了,则显示用户登录,脚本终止;
  (2) 每3秒钟,查看一次用户是否登录;
    #!/bin/bash
    #
    while [ 0 -eq 0 ];do
            if who|grep "magedu" &>/dev/null;then
                    echo "The user magedu login already"
                    exit 44
            fi
            sleep 3
            echo "wait user magedu login"
    done
    或者
    #!/bin/bash
    #
    until [ 1 -eq 2 ];do
            if who|grep "magedu" &> /dev/null;then
                    exit 22
            fi
            sleep 3

    done

6、写一个脚本,显示用户选定要查看的信息;
   cpu) display cpu info
   mem) display memory info
   disk) display disk info
   quit) quit
   非此四项选择,则提示错误,并要求用户重新选择,只到其给出正确的选择为止;
    #!/bin/bash
    #
    echo -e "cpu) display cpu info\nmem) display memory info\ndisk) display disk info\nquit) quit\n"
    while [ 0 -eq 0 ];do
    read -p "please input you choice: " i
    case $i in
    "cpu")
            lscpu
            break
            ;;
    "mem")
            free -m
            break
            ;;
    "disk")
            df -lh
            break
            ;;
    "quit")
            echo "quit"
            break
            ;;
    *)
            echo "Eror choice,please input again"           
            ;;
    esac
    done

7、写一个脚本
  (1) 用函数实现返回一个用户的UID和SHELL;用户名通过参数传递而来;
  (2) 提示用户输入一个用户名或输入“quit”退出;
    当输入的是用户名,则调用函数显示用户信息;
    当用户输入quit,则退出脚本;进一步地:显示键入的用户相关信息后,再次提醒输出用户名或quit:
    #!/bin/bash
    #
    function User {
            echo "UID=`id -u $yonghu`"
            SHELL=`grep $yonghu /etc/passwd|awk -F: '{printf $7}'`
            echo "SHELL=$SHELL"
    }
    while [ 0 -eq 0 ];do
    read -p "please input a para(A user or quit): " yonghu
    if id $yonghu&>/dev/null;then
            User
    elif [ $yonghu == "quit" ];then
            break
    else
            echo -e "no such this user\n"
    fi
    done
    echo "End"

8、写一个脚本,完成如下功能(使用函数)
   (1) 提示用户输入一个可执行命令的名字;获取此命令依赖的所有库文件;
   (2) 复制命令文件至/mnt/sysroot目录下的对应的rootfs的路径上,例如,如果复制的文件原路径是/usr/bin/useradd,则复制到/mnt/sysroot/usr/bin/目录中;
   (3) 复制此命令依赖的各库文件至/mnt/sysroot目录下的对应的rootfs的路径上;规则同上面命令相关的要求;
    #!/bin/bash
    #
    sys=/mnt/sysroot
    read -p "Input a command: " comd
    path=`whereis $comd|awk '{print $2}'`
    if [ -d `dirname ${sys}${path}` ];then
            cp $path ${sys}${path}
    else
            mkdir -p ${sys}${path}
            cp $path ${sys}${path}
    fi
    for i in $(ldd $path|grep -o "/.*lib.*\.so.*\.[^[:space:]]");do
            if [ -d `dirname ${sys}$i` ];then
                    cp -r $i `dirname ${sys}$i`
            else
                    mkdir -p ${sys}`dirname ${sys}$i`
                    cp -r $i `dirname ${sys}$i`
            fi
    done

   

原创文章,作者:N22-北京-喜欢就好,如若转载,请注明出处:http://www.178linux.com/56922

(0)
N22-北京-喜欢就好N22-北京-喜欢就好
上一篇 2016-11-07
下一篇 2016-11-07

相关推荐

  • Linux系统的软链接和硬链接

    Linux的链接是一种共享文件和访问它的用户的若干目录项之间建立联系的一种方法。一共分为两种链接,分别是软链接和硬链接。 一、硬链接 1、硬链接的本质上是一个文件,它们除了名字不一样,其他都一样,占用的空间是一个。硬链接会增加文件的链接数。如下图 (1)建立硬链集之前     (2)建立硬链接之后 2、删去一个链接名,链接数减一…

    Linux干货 2016-10-22
  • java基础篇—内存分析

    Java的并发采用的是共享内存模型(而非消息传递模型),线程之间共享程序的公共状态,线程之间通过写-读内存中的公共状态来隐式进行通信。多个线程之间是不能直接传递数据交互的,它们之间的交互只能通过共享变量来实现 同步是显式进行的。程序员必须显式指定某个方法或某段代码需要在线程之间互斥执行。 1、多线程通信 1.1 内存模型 Java线程之间的通信由Java内存…

    Linux干货 2015-03-16
  • 第四周作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@wlm ~]# useradd tuser1 [root@wlm ~]# cp -r etc/skel/ /home/tuser1/…

    Linux干货 2016-11-21
  • Redis的编译安装

    介绍     redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set –有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更…

    Linux干货 2015-02-28
  • Linux文件管理及常用方法

    Linux文件管理及常用方法 一切皆文件,管理系统即用正确的方法管理相应的文件。 Linux系统中文件管理所涉及到的问题 ls -l boot.log   -rw-r–r–. 1 root   root     13…

    Linux干货 2016-11-06
  • iptables基础详解

    一.iptables基础认知二.iptables使用格式  一.iptables简介   1.Iptabels是与Linux内核集成的包过滤防火墙系统,几乎所有的linux发行版本都会包含Iptables的功能。如果 Linux 系统连接到因特网或LAN、服务器或连接 LAN 和因特网的代理服务器, 则Iptables有利于在 …

    2017-05-03

评论列表(1条)

  • 马哥教育
    马哥教育 2016-11-10 13:23

    写的还是比较详细的,有个地方 需要注意下 while [ 0 -eq 0 ] 其实就是 while true 做循环. 还有那个until 的用法也需要看下。加油~