Net25-第10周作业

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

Centos系统启动过程分内核空间启动和用户空间启动:

内核空间启动流程:

  • POST: post加点自检,检测计算机基本5大件是否完好,计算机可被正常点亮。
  • BootSequence: 位于ROM上的BIOS的BootSequence来选择启动顺序
  • Bootloader: 决定启动顺序后,在启动设备上的MBR的前446bytes加载bootloader
  • Ramdisk: bootloader需要引导内核的加载,在这过程需要加载ramdisk来驱动真正的内核加载
  • rootfs: 内核加载后将根文件系统以只读的方式挂载
  • /sbin/init: 启动1号进程,/sbin/init,接下来的系统的管理都交给了1号进程

用户空间启动流程:

  • 设置默认的运行级别
  • 运行系统初始化脚本(/etc/rc.d/rc.sysinit),完成系统初始化
  • 关闭对应级别下需要关闭的服务
  • 启动对应级别下需要启动的服务
  • 设置登陆终端

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

  • (1) 为硬盘新建两个主分区;并为其安装grub;
  • (2) 为硬盘的第一个主分区提供内核和ramdisk文件; 为第二个分区提供rootfs;
  • (3) 为rootfs提供bash、ls、cat程序及所依赖的库文件;
  • (4) 为grub提供配置文件;
  • (5) 将新的硬盘设置为第一启动项并能够正常启动目标主机;
以下是我的分区:

    /dev/sdb1 boot 200M
    /dev/sdb2 / 2G
    /dev/sdb3 swap 1G

在/mnt下创建/boot /sysroot目录

挂载/dev/sdb1到/mnt/boot,/dev/sdb2到/mnt/sysroot

创建grub
# grub-install --root-directory=/mnt /dev/sdb
复制linux内核与ramdisk
# cp /boot/vmlinuz-2.6.32-642.el6.x86_64 /mnt/boot/vmlinuz
# cp /boot/initramfs-2.6.32-642.el6.x86_64.img /mnt/boot/initramfs.img
创建grub.conf
# cd /mnt/boot/grub
# vim grub.conf
default 0
timeout 5
title Centos (zgx)
        root (hd0,0)
        kernel /vmlinuz ro root=/dev/sda2 selinux=0 init=/bin/bash
        initrd /initramfs.img
创建根文件系统目录
# cd /mnt/sysroot
# mkdir bin  sbin dev  etc  home  lib  lib64   media  mnt  proc  root  sbin  sys  tmp  usr  var
拷贝几个程序
# cp /bin/bash /mnt/sysroot/bin
# ldd /bin/bash 
        linux-vdso.so.1 =>  (0x00007ffcdc8d5000)
        libtinfo.so.5 => /lib64/libtinfo.so.5 (0x00007f973fc3a000)
        libdl.so.2 => /lib64/libdl.so.2 (0x00007f973fa36000)
        libc.so.6 => /lib64/libc.so.6 (0x00007f973f6a1000)
        /lib64/ld-linux-x86-64.so.2 (0x00007f973fe64000)
# cp /lib64/libtinfo.so.5 lib64/
# cp /lib64/libdl.so.2 lib64/
# cp /lib64/libc.so.6 lib64/
# cp /lib64/ld-linux-x86-64.so.2 lib64/
# sync

将这块硬盘作为虚拟机的启动盘,可以正常的启动小linux

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

在图形界面界面制作安装system-config-kickstart

在图形界面制作个kickstart

#修改引导镜像的内核参数
#mount /dev/cdrom /mnt/cdrom
#mkdir /myboot
#cp /mnt/cdrom/ioslinux /myboot
#cp ks.cfg /myboot
#cd /mnt/cdrom/ioslinux
#vim isolinux.cfg
...
label linux
  menu label ^Install or upgrade an existing system
  menu default
  kernel vmlinuz
  append initrd=initrd.img ks=cdrom:/ks.cfg
...
#cd /
#重新封装引导镜像
#mkisofs -R -J -T -v --no-emul-boot --boot-load-size 4 --boot-info-table -V "Centos 6 x86_64 boot" -c isolinux/boot.cat -b isolinux/isolinux.bin -o /root/boot.iso myboot

将引导镜像进行安装可以进行自动安装

4、写一个脚本

  • (1) 能接受四个参数:start, stop, restart, status
    start: 输出“starting 脚本名 finished.”
  • (2) 其它任意参数,均报错退出;
#!/bin/bash

pidfile=/var/run/myservice.pid

start() {

   if [ -e $pidfile ];then
        echo "myservice aleardy start."
    else
        pid=$$
        echo "${pid}" > $pidfile
        echo "starting myservice finished"  
   fi
}

stop() {
   if [ -e $pidfile ];then
        rm -f $pidfile
        echo "stopping myservice finished"
    else
        echo "myservice is not running"
    fi        
}

case $1 in 
start)
    start
    ;;
stop)
    stop
    ;;
restart)
    stop
    start
    ;;
status)
    if [ -e $pidfile ];then
        echo "myservice is running"
    else
        echo "myservice is not running"
    fi
    ;;
*)
    echo "Usage: $0 [start|stop|restart|status]"
esac

5、写一个脚本,判断给定的用户是否登录了当前系统;

  • (1) 如果登录了,则显示用户登录,脚本终止;
  • (2) 每3秒钟,查看一次用户是否登录;
#!/bin/bash
while true;do
    if who | grep ansible &> /dev/null;then
        echo "ansible aleardy login."
        break
    else
        sleep 3
        continue
    fi
done

6、写一个脚本,显示用户选定要查看的信息;

  • cpu) display cpu info
  • mem) display memory info
  • disk) display disk info
  • quit) quit

非此四项选择,则提示错误,并要求用户重新选择,只到其给出正确的选择为止;

#!/bin/bash
cat << EOF
cpu) display cpu info
mem) display memory info
disk) display disk info
quit) quit
EOF

while true;do
read -p "please choose:" choose
case ${choose} in 
cpu)
    lscpu
    ;;
mem)
    free -m
    ;;
disk)
    df -HT
    ;;
quit)
    exit
    ;;
*)
    continue
esac
done

7、写一个脚本

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

    grep "^$1\>" /etc/passwd |awk -F':' '{print "user",$1,"uid",$3}'
}

while true;do
read -p "enter a user:" username
if [ $username == 'quit' ];then
    break
else
    user $username
    echo "enter quit to exit"
fi
done

8、写一个脚本,完成如下功能(使用函数)

  • (1) 提示用户输入一个可执行命令的名字;获取此命令依赖的所有库文件;
  • (2) 复制命令文件至/mnt/sysroot目录下的对应的rootfs的路径上,例如,如果复制的文件原路径是/usr/bin/useradd,则复制到/mnt/sysroot/usr/bin/目录中;
  • (3) 复制此命令依赖的各库文件至/mnt/sysroot目录下的对应的rootfs的路径上;

规则同上面命令相关的要求;

#!/bin/bash
target=/mnt/sysroot
cmd() {
if which $cmd $> /dev/null;then
    cmdpath=`which --skip-alias $cmd`
else
    echo "no such command"
    return 6
fi
}

cmdcopy() {
cmddir=`dirname $1`
[ -d ${target}${cmddir} ] || mkdir -p ${target}${cmddir}
[ -f ${target}${1} ] || cp $1 ${target}${cmddir} 
}

libcopy(){
for lib in `ldd $1 | grep -o "/[^[:space:]]\{1,\}"`;do
libdir=`dirname $lib`
[ -d ${target}${libdir} ] || mkdir -p ${target}${libdir}
[ -f ${target}${lib}  ] || cp $lib ${target}${libdir}
done
}
while true;do
read -p "enter a command:" cmd
if [ "$cmd" == 'quit' ];then
echo quit
exit 0
fi

cmd $cmd
[ $? -eq 5 ] && continue

cmdcopy $cmdpath
libcopy $cmdpath

done

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

(0)
N25_随心N25_随心
上一篇 2017-03-15
下一篇 2017-03-15

相关推荐

  • nginx初步

    一、知识整理 1、查看进程使用的cpu;ni查看nice值 [root@localhost html]# ps axo pid,comm,psr,ni  43769 nginx          &n…

    Linux干货 2016-10-31
  • 第1周-1:计算机的组成及其功能以及部分常见Linux发行版简介

    一、计算机的组成及其功能: 计算机主要由硬件部分和软件部分组成。 1、硬件部分 (1)中央处理器 由控制器和运算器两大部分组成,是计算机的大脑,硬件部分里最关键的部分。决定着整个计算机系统的性能。 控制器负责协调计算机硬件的其他部分同步工作,对其他的硬件进行发号施令。是计算机系统的司令。控制器从存储器中读取指令,分析指令的含义,要完成什么操作,需要什么数据,…

    Linux干货 2016-11-01
  • 马哥教育网络班N22期+第9周课程练习

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bashnolo_user=0login_user=0while read user;do    bash_type=$(e…

    Linux干货 2016-10-21
  • Linux系统之用户和组

    Linux系统之用户和组 1、什么是用户 用户:资源获取标识符,资源分配,安全权限模型的核心要素之一 2、没有用户,操作系统可否正常执行? 答案是肯定的 在Linux系统上,用户管理是基于用户名和密码的方式进行资源的分配, Username/UID分为以下类别:     管理员:root, 0  &…

    Linux干货 2016-08-04
  • 路由配置注意事项

    路由配置注意事项 在把linux主机当做路由的时候,切记把转发功能打开,防火墙关闭,否则到头来一场空。 红脸主机: 黄脸主机: 路由A: [root@localhost network-scripts]# ip route 192.168.240.0/24 via 10.0.0.11 dev eth1 172.16.0.0/16 dev eth0 proto…

    2017-05-03
  • 作业权限管理

    一、在/data/testdir里创建的新文件自动属于g1组,组g2的成员如:alice能对这些新文件有读写权限,组g3的成员如:tom只能对新文件有读权限,其它用户(不属于g1,g2,g3)不能访问这个文件夹。 首先创建三个组g1,g2,g3,题目要求在/data/testdir目录里创建的文件自动属于g1组那么首先要将这个目录的属组改为g1,然后通过更改…

    Linux干货 2016-08-03

评论列表(1条)

  • 马哥教育
    马哥教育 2017-03-29 17:15

    作业品质保持的很好,继续加油。