第十周 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)
上一篇 2016-09-26 07:43
下一篇 2016-09-26 07:44

相关推荐

  • linux 计划任务

    Linux之 计划任务 介绍 相信每个人都有使用闹钟的习惯,我们设定闹钟的种类有很多。比如说,只提醒一次、工作日提醒、休息日提醒等。在设定闹钟之后,每天的设定时间都会按时的提醒你去做什么事情,以免自己忘记一些重要的会议等事情。像这样在每天特定的时间安排做一些事情。这样一种事情我们就称之为例行任务计划。 其实在个系统平台上都有类似的例行性任务计划功能,那如何去…

    Linux干货 2017-09-04
  • N23-第五周博客作业

    1、显示当前系统上root、fedora或user1用户的默认shell。 [root@localhost ~]# cat /etc/passwd | egrep "^root\>" | cut -d: -f1,7 2、找出/etc/rc.d/init.d/functions文件中某单词后面跟一组小括号的行,形如:hell…

    Linux干货 2016-12-05
  • nginx配置(三)

    ngx_http_upstream_module模块     #分流The ngx_http_upstream_module module is used to define groups of servers that can be referenced by the proxy_pass, fastcgi_pass, uwsgi_pa…

    Linux干货 2017-05-08
  • 基于ssl协议和openssl工具建立私有CA

    前言     要自建CA需先了解openssl工具和ssl协议还有各加密类型     ssl(Secure Socket Layer)安全套接字层当前版本为3.0,浏览器与Web服务器之间的身份认证和加密数据传输,它工作在传输层和各应用层之间,用户可以选择是否使用ssl进行传输,选择ssl协议将调用…

    Linux干货 2015-05-07
  • 正则表达式

    什么是正则表达式? 正则表达式(Regular Expression)是一种文本模式,包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称为”元字符”)。正则表达式使用单个字符串来描述、匹配一系列匹配某个句法规则的字符串,许多程序设计语言都支持利用正则表达式进行字符串操作。正则表达式是烦琐的,但它是强大的,学会之后的应用会让你除…

    Linux干货 2017-06-01
  • 重构-改善既有代码的设计:重构原则(二)

    1.什么是重构 重构(Refactoring):在不改变软件的功能和外部可见性的情况下,为了改善软件的结构,提高清晰性、可扩展性和可重用性而对软件进行的改造,对代码内部的结构进行优化。 2.为何重构   1)改进软件设计(整理代码) 重构和设计是相辅相成的,它和设计彼此互补。有了重构,你仍然必须做预先的设计,但是不必是最优的设计,只需要一个合理的解…

    Linux干货 2015-04-07

评论列表(1条)

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

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