从Linux小白到大牛——与狼共舞的日子10

马哥教育网络班21期+第10周课程练习

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


POST --> Boot Sequence(BIOS) --> Boot Loader(MBR) 
 --> Kernel+ramdisk(initrd) --> rootfs --> /sbin/init 
 --> (/etc/inittab,/etc/init/*.conf)

(1)加电自检:POST
    通电后主板CMOS中的BIOS进行硬件自检;

(2)BIOS,引导加载次序:Boot Squence
    按照BIOS中的设备启动顺序,找到第一个有引导程序的设备作为启动的设备;

(3)bootloader
    引导加载器,引导并提供菜单,让用户选择要启动的系统把选定的内核装载到
    内存中的特定空间中,解压、展开,并把系统控制权限移交给内核;

(4)kernel初始化操作
    探测可识别的所有硬件设备;加载硬件驱动;以只读方式挂在根文件系统;
    运行用户空间的第一个应用程序:/sbin/init

(5)init阶段
    根据对应的运行级别运行对应的运行级别定义的脚本

(6)运行初始化脚本
    系统初始化脚本对应文件:/etc/rc.d/rc.sysinit,设置主机名等信息,检测
    根文件系统,激活swap等;

(7)启动系统服务
    根据/etc/rc.d/init.d目录下的脚本启动相应的系统服务;

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

  • (1) 为硬盘新建两个主分区;并为其安装grub;

  • (2) 为硬盘的第一个主分区提供内核和ramdisk文件; 为第二个分区提供rootfs;

  • (3) 为rootfs提供bash、ls、cat程序及所依赖的库文件;

  • (4) 为grub提供配置文件;

  • (5) 将新的硬盘设置为第一启动项并能够正常启动目标主机;


[root@localhost ~]# lsblk /dev/sdb
  NAME   MAJ:MIN RM SIZE RO TYPE MOUNTPOINT
  sdb  8:16   0  60G  0 disk 
  ├─sdb1   8:17   0  10G  0 part 
  └─sdb2   8:18   0  10G  0 part

[root@localhost ~]# mkfs.ext4 /dev/sdb1
[root@localhost ~]# mkfs.ext4 /dev/sdb2

[root@localhost ~]# mkdir /mnt/{boot,sysroot}

[root@localhost ~]# mount /dev/sdb1 /mnt/boot/
[root@localhost ~]# mount /dev/sdb2 /mnt/sysroot/

[root@localhost ~]# grub-install --root-directory=/mnt /dev/sdb

[root@localhost ~]# cp /boot/initramfs-2.6.32-358.el6.x86_64.img /mnt/boot/initramfs.img
[root@localhost ~]# cp /boot/vmlinuz-2.6.32-358.el6.x86_64 /mnt/boot/vmlinuz

[root@localhost ~]# vim /mnt/boot/grub/grub.conf
  default=0
  timeout=5
  title CentOS 6
  root (hd0,0)
  kernel /vmlinuz ro root=/dev/sda2 selinux=0 init=/bin/bash
  initrd /initramfs.img

[root@localhost ~]# bash cpcommand.sh  #第八题的脚本
                    将ls,bash,cat命令及所依赖的库文件复制到/mnt/sysroot/中,
                    并将新加的磁盘挂载到新虚拟机中启动测试

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


创建kickstart文件的方式:
            (1) 直接手动编辑;
                依据某模板修改;
            (2) 可使用创建工具:system-config-kickstart (CentOS 6)
                依据某模板修改并生成新配置;

[root@localhost ~]# yum install system-config-kickstart -y
[root@localhost ~]# system-config-kickstart  #使用kickstart图形另存为一个kickstart文件


kickstart文件的格式:
        命令段:指明各种安装前配置,如键盘类型等;
        程序包段:指明要安装的程序包组或程序包,不安装的程序包等;
            %packages
            @group_name
            package
            -package
            %end
        脚本段:
            %pre: 安装前脚本
                运行环境:运行于安装介质上的微型Linux环境

            %post: 安装后脚本
                运行环境:安装完成的系统;

        命令段中的命令:
            必备命令
                authconfig: 认证方式配置
                    authconfig --useshadow  --passalgo=sha512
                bootloader:bootloader的安装位置及相关配置
                    bootloader --location=mbr --driveorder=sda 
                               --append="crashkernel=auto crashkernel=auto 
                                 rhgb rhgb quiet quiet"
                keyboard: 设定键盘类型
                lang: 语言类型
                part: 创建分区
                rootpw: 指明root的密码
                timezone: 时区

            可选命令
                install OR upgrade
                text: 文本安装界面
                network
                firewall
                selinux
                halt
                poweroff
                reboot
                repo
                user:安装完成后为系统创建新用户
                url: 指明安装源

创建引导光盘:
            1)复制系统安装光盘/Packages /repodata外的所有文件到目录/myiso/
            2)创建引导光盘镜像
            # mkisofs -R -J -T -v --no-emul-boot --boot-load-size 4 
              --boot-info-table -V "CentOS 6.6 x86_64 boot" 
              -b isolinux/isolinux.bin -c isolinux/boot.cat -o /root/boot.iso myiso/

4、写一个脚本

  • (1) 能接受四个参数:start, stop, restart, status

  • start: 输出“starting 脚本名 finished.”

  • (2) 其它任意参数,均报错退出;


[root@localhost ~]# cat status.sh 
#!/bin/bash
#
[ -d /var/log/subsys ] || mkdir -p /var/log/subsys
lockfile=/var/log/subsys/$0
Usage(){
    echo "Usage:$0 (start|stop|restart|status)" 
}

Start(){
    [ -e $lockfile ] && echo "$0 already Started." || touch $lockfile && echo "Starting $0 finished."
}

Stop(){
    [ -e $lockfile ] && rm -f $lockfile && echo "Stoping $0 finished." || echo "$0 no Running."
}

Status(){
    [ -e $lockfile ] && echo "$0 is Running." || echo "$0 is Stopped."
}

[ $# -ne 1 ] && Usage && exit 1

case $1 in
    start)
        Start;;
    stop)
        Stop;;
    restart)
        Stop&&Start;;
    status)
        Status;;
    *)
        Usage
        exit 2
        ;;
esac

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

  • (1) 如果登录了,则显示用户登录,脚本终止;

  • (2) 每3秒钟,查看一次用户是否登录;


[root@localhost ~]# cat userlogin.sh 
#!/bin/bash
#
[ $# -ne 1 ] && echo "Usage:$0 username" && exit 1
while true;do
    who | grep "^\<$1\>" &>/dev/null && echo "$1 Login." && exit 0 || sleep 3
done

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

  • cpu) display cpu info

  • mem) display memory info

  • disk) display disk info

  • quit) quit

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


[root@localhost ~]# cat display.sh 
#!/bin/bash
#
cat << EOF
cpu) display cpu info
mem) display memory info
disk) display disk info
quit) quit
========================
EOF
Chose(){
read -p "Choose a option:(cpu|mem|disk|quit)" option
}

Chose
until [ $option == "quit" ];do
    case $option in
        cpu)
            lscpu && Chose;;
        mem)
            free -m && Chose;;
        disk)
            lsblk && Chose;;
    *)
            echo "Error,chose again!" && Chose;; 
    esac
done

7、写一个脚本

  • (1) 用函数实现返回一个用户的UID和SHELL;用户名通过参数传递而来;

  • (2) 提示用户输入一个用户名或输入“quit”退出;

  • 当输入的是用户名,则调用函数显示用户信息;

  • 当用户输入quit,则退出脚本;进一步地:显示键入的用户相关信息后,再次提醒输出用户名或quit:


[root@localhost ~]# cat uidshell.sh 
#!/bin/bash
Show(){
    uid=`id -u $1`
    usershell=`grep "^\<$1\>" /etc/passwd | cut -d: -f7`
    echo "UID:$uid  Shell:$usershell" && chose
}

chose(){
    read -p "Enter a Username or quit:" username
}

chose
until [ $username == "quit" ];do
    ! id $username &>/dev/null && echo "No such User." && chose || Show $username
done

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

  • (1) 提示用户输入一个可执行命令的名字;获取此命令依赖的所有库文件;

  • (2) 复制命令文件至/mnt/sysroot目录下的对应的rootfs的路径上,例如,如果复制的文件原路径是/usr/bin/useradd,则复制到/mnt/sysroot/usr/bin/目录中;

  • (3) 复制此命令依赖的各库文件至/mnt/sysroot目录下的对应的rootfs的路径上;规则同上面命令相关的要求;


[root@localhost ~]# cat cpcommand.sh 
#!/bin/bash
#
dir=/mnt/sysroot
cpbin(){
bincmddir=`echo $cmd | grep -o -E "^/.*/"`
[ -d $dir$bincmddir ] || mkdir -p $dir$bincmddir
[ -z $dir$cmd ] || cp $cmd $dir$bincmddir
}

cplib(){
liblist=`/usr/bin/ldd $cmd | grep -o "[^[:space:]]*/lib[^[:space:]]*"`
for lib in $liblist;do
    cmddir=`echo $lib | grep -o -E "^/.*/"`
    [ -d $dir/$cmddir ] || mkdir -p $dir$cmddir
    [ -z $dir/$lib ] || cp $lib $dir$cmddir
done
}
   
while true;do
read -p "Enter a Command:(Commamd|quit)" command
[ $command == "quit" ] && echo "quit..." && exit 0
which $command &>/dev/null && cmd=`which --skip-alias $command` || echo "No correct Command."
[[ -x $cmd ]] && cpbin $command && cplib $command || echo "No correct Command."
done

原创文章,作者:N21_孤狼,如若转载,请注明出处:http://www.178linux.com/60676

(0)
上一篇 2016-12-05 17:05
下一篇 2016-12-05 17:05

相关推荐

  • 发送mail的几种方法

    mail,顾名思义就是邮件。在这两天上课中,接触了发送mail的一些用法,课下自己在网上又查询补充了一下,总结出来,增加印像。 为了显示清晰,首先我们分别使用两个用户在不同的终端下登录,一个超级管理员root,一个是刚刚创建的用户zhangsan,看下图: 首先先来看一下发送mail用到什么选项:  -s<邮件主题>:指定邮件的主题; …

    2017-07-20
  • Linux常见文件管理命令

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。2、bash的工作特性之命令执行状态返回值和命令行展开所涉及的内容及其示例演示。3、请使用命令行展开功能来完成以下练习:(1)、创建/tmp目录下的:a_c, a_d, b_c, b_d(2)、创建/tmp/mylinux目录下的:mylinux/├── bin├── boot│  …

    2018-02-26
  • 作业–权限管理

    1、当用户wangcai对/testdir目录无写权限时,该目录下的只读文件file1是否可修改和删除? [root@liang testdir]# su wangcai [wangcai@liang testdir]$ ll -a 总用量 8 drwxr-xr-x. &nbsp…

    Linux干货 2016-08-05
  • N22-​Linux系统的基础命令

                                     Linux系统的基础命令 命令的语法通用格式:# COMMAND OPTIONS  ARGUMENTS COMMA…

    Linux干货 2016-08-15
  • Linux的终端类型

            Linux的终端类型         Linux终端的定义         Linux终端的分类 &nb…

    Linux干货 2016-10-18
  • Nginx浅谈(一)

    浅谈nginx(一) 此文主要介绍nginx的基础知识及其基本配置,一为巩固,二为记录 知识点: nginx的作用 nginx的基本配置框架 nginx一些常用模块介绍 1、什么是nginx     nginx是一款免费的,开源的,高性能的HTTP服务软件,它不仅能     够支…

    Linux干货 2017-01-15