第十周 N21 总有刁民想害朕

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

  加电-MBR-GRUB-/sysinit-init X 对应的服务-/etc/rc.d

    MBR 

      读取分区表

    GRUB 

      加载GRUB STAGE1 1.5 2 阶段,读取/boot/grub.conf 装载kernel和initrd到内存

    内核阶段  

      运行内核参数 initrd和必要驱动 挂载根文件系统

    init用户空间初始化

      启动/sbin/init

      运行rc.sysinit 系统环境 swap分区

      读取/etc/inittab 

      /etc/rc.d/rcX/d运行级别下的S 和 K开头的文件

      打开终端,显示允许登陆 

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

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

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

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

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

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

grub-install --root-directory=ROOT /dev/disk
      mkinitrd
      cp -r `which bash` /dev/sdb2
      cp -r `which cat`  /dev/sdb2
      ldd bash
      ldd cat
      cat grub.conf
             title  TITLE:定义菜单项的标题,可出现多次,
                root(hd0,0)
                kernel  bzImage   root=/dev/sda2

            

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

   1、anaconda的配置方式:

    (1) 交互式配置方式;

    (2) 通过读取事先给定的配置文件自动完成配置;

    a)按特定语法给出的配置选项;

       kickstart文件;

      b)安装引导选项:

        text: 文本安装方式

        method: 手动指定使用的安装方法

      c)与网络相关的引导选项:

        ip=IPADDR

        netmask=MASK

        gateway=GW

        dns=DNS_SERVER_IP

        ifname=NAME:MAC_ADDR

              d)与远程访问功能相关的引导选项:

        vnc

        vncpassword='PASSWORD'

              e)指明kickstart文件的位置

        ks=

        DVD drive: ks=cdrom:/PATH/TO/KICKSTART_FILE

        Hard drive: ks=hd:/device/drectory/KICKSTART_FILE

        HTTP server: ks=http://host:port/path/to/KICKSTART_FILE

        FTP server: ks=ftp://host:port/path/to/KICKSTART_FILE

        HTTPS server: ks=https://host:port/path/to/KICKSTART_FILE

      f)启动紧急救援模式:

        rescue

2、 kickstart文件的格式:

     a)命令段:指明各种安装前配置,如键盘类型等;

     b)程序包段:指明要安装的程序包组或程序包,不安装的程序包等;

           %packages

           @group_name

           package

           -package

           %end

     c)脚本段:

           %pre: 安装前脚本

               d)运行环境:运行于安装介质上的微型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: 指明安装源

创建kickstart文件的方式:

  (1) 直接手动编辑;

      依据某模板修改;

  (2) 可使用创建工具:system-config-kickstart (CentOS 6)

      依据某模板修改并生成新配置;

检查ks文件的语法错误:ksvalidator

  # ksvalidator /PATH/TO/KICKSTART_FILE

创建引导光盘:

  # mkisofs -R -J -T -v –no-emul-boot –boot-load-size 4 –   boot-info-table -V “CentOS 6.8 x86_64 boot” 

  -b isolinux/isolinux.bin -c isolinux/boot.cat -o /root/boot.iso myiso/

[root@localhost ~]# yum install system-config-kickstart

[root@localhost ~]# system-config-kickstart # 进入图形界面

4、写一个脚本

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

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

   …

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

#/bin/bash
     usage(){
      echo "usage: $prog {start | restart | stop | status}" 
    }
      if [ $1 -lt 1 ];then
      usage
      exit 2
      fi
    case $1 in
     start)
      start;;
     stop) 
      stop;;
     restart)
      stop
      start;;
     status)
      status;;
     *)
      usage
    esac

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

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

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

    #!/bin/bash
    read -p "give me a username and i will check whether it logged" $username
    until false
    if who | grep $username &>/dev/null;then
    break
    fi
    sleep 3
    done
    echo "$username already logged"

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

   cpu) display cpu info

   mem) display memory info

   disk) display disk info

   quit) quit

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

#/bin/bash
  hehe () {echo "$hehe: $dd {cpu|mem|disk|quit}
  if [$1 -lt 1];then
  hehe && exit 3
  fi
  case $1 in
  cpu)
    cat /proc/cpuinfo
  mem)
    free -m
  disk)
    fdisk -l /dev/sd[a-z][1-9]
  quit)
    exit 10
  *)
  hehe
  esac

7、写一个脚本

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

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

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

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

    #/bin/bash
    666(){
    read -p : " plz int a username or "quit" to exit " $username
    case $username in
    UID)
        echo "`id $username`" && 666;;
    SHELL)
        echo "cat /etc/passwd | egrep "^$username" | cut -d: -f7" && 666
    quit)
        exit 5;;
        }

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

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

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

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

#!/bin/bash
read -p "int a  cmd" cmd
path=`which $cmd`
lib=`ldd $path | egrep -o "/[^[:space:]]+"` 
cppath(){
        cp $path /mnt/sysroot$path
        echo "copy $cmd  completed."
}
cplib(){        
         for i in $lib;do
                cp $i /mnt/sysroot$path
                echo "copy $i_lib completed."
                done
}
cppath
cplib
#感谢人至贱则无敌的 志建 班长提供的帮助和解答

原创文章,作者:N21-总有刁民想害朕,如若转载,请注明出处:http://www.178linux.com/47797

(0)
N21-总有刁民想害朕N21-总有刁民想害朕
上一篇 2016-09-26
下一篇 2016-09-26

相关推荐

  • 自动化运维之Cobbler

    自动化运维:         随着信息时代的持续发展,IT运维已经成为IT服务内涵中重要的组成部分。面对越来越复杂的业务,面对越来越多样化的用户需求,不断扩展的IT应用需要越来越合理的模式来保障IT服务能灵活便捷、安全稳定地持续保障,这种模式中的保障因素就是IT运维(其他因素是更…

    Linux干货 2016-04-21
  • 初学Linux之文件查找和压缩

    使用locate命令 ,使用find命令 ,压缩和解压缩工具

    2018-01-13
  • 配置epl时,出现“time out”错误,解决办法

    一:配置环境、网络环境及出现的故障 1:配置环境 本机在配置epel仓库时,配置文件所在路径为/etc/yum/repos.d/centos7.repo.以下为配置文件的的详细内容 [base]name=centos 7.3baseurl=file:///misc/cdgpgkey=file:///misc/cd/RPM-GPG-KEY-Centos-7 […

    2017-06-10
  • N25第八周学习总结_sed命令详解

    sed使用详解 大纲: 1、    sed是什么 2、    为什么要使用sed 3、    sed使用方法 4、    sed详解   正题: 1、    sed是什么 sed全名Stream Ed…

    2017-02-26
  • 在CentOS 7上实现私有CA及申请和吊销证书

    – 创建私有CA openssl的配置文件:/etc/pki/tls/openssl.cnf 42 dir     = /etc/pki/CA       # Where everythi…

    Linux干货 2016-12-01
  • 第十九周作业

    1、描述Tomcat的架构; 核心架构图: 架构简介: Server是管理Service接口的,是Tomcat的一个顶级容器。管理着多个Service; Service 是服务,管理着一个Container和多个Connector,Service的存在依赖于Server; Container : 一个或者多个Container 可以对应一个Connector…

    2017-06-23

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-27 09:37

    写的很好,注意一下排版,写脚本的时候可以多写一些判断条件