Linux 系统启动流程及bash 脚本编程练习

马哥教育网络班23期 第10周课堂练习

Linux 系统启动流程及bash 脚本编程练习

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

Capture1.PNG

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

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

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

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

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

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

步骤:

  1. 首先对这个硬盘进行分区:

 Capture2.PNG

boot 所在分区分5G /分区分10G

Capture3.PNG

2.对所在分区进行格式化

Capture4.PNG

3.格式化之后,对其进行挂载

 Capture5.PNG

然后在第一个分区上安装grub 也就是/dev/sdb1 上安装

 Capture6.PNG

验证一下是否安装成功:

Capture7.PNG

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

也就是copy 内核文件 和 initrd 文件到/myroot/boot 下

Capture11.PNG

5.为grub提供配置文件

[root@localhost grub]# cp /boot/grub/grub.conf ./

6.为rootfs提供bash、ls、cat程序及所依赖的库文件;

首先,在/myroot/root 下创建类似bin sbin usr dev …这些目录 
然后写一个脚本,我这里准备了一个脚本,可以复制二进制主文件和库文件

 #!/bin/bash
prog=/mnt/sysroot/root
usage(){
 echo "usage:`basename $0` options is a type shell"
 exit 1
}
quit(){
 echo "this programe is exitting..."
 exit 0
}
compare(){
 local _shell=`which $1`
 [ $? -ne 0  ] && usage
 cp -r  $_shell  ${prog}$_shell
 declare -a shellarray=`ldd $_shell | egrep -o \/\.+[[:space:]]`
 for i in ${shellarray[@]}
 do
   #cp -r {prog}${i} 
  # path_lib64=`ls -l ${i} | awk '{if($NF ~/^\//){print $NF}else {print  "/lib/"$NF}}'`
  # if [ ${path_lib64%/*} == "/lib" ];then
     cp  $i  $prog/lib 
  #  else
  #   cp  ${path_lib64}  $prog/lib
  # fi
 done
}
if [ $# -eq 0 ];then 
  usage
fi 
case $i in 
quit)
 quit
;;
*)
compare $1
;;
esac

7.最后,把这块硬盘挂载到新的虚拟机上运行测试结果。

4、写一个脚本

(1)能接受四个参数:start, stop, restart, status,start: 输出“starting 脚本名 finished.”

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

#!/bin/bash
    # chkconfig: 2345 50 60
    # description: this service is testing 
    prog=/tmp/service.file
    command=`basename $0`
    start(){
      [ -f $prog ] && echo "$command is running.." || touch $prog  
    } 
    stop(){
      [ -f $prog ] && rm -rf $prog || echo "$command is stopped.."
    }
    restart(){
      stop
      start
    }
    status(){
      [ -e $prog ] && echo "$command is running.." || echo "$command is stopped.."
    }
    Usage(){
      echo "Usage: $command {start|stop|restart|status}.."
      exit 2
    }
    case $1 in 
    start)
    start 
    ;;
    stop)
    stop
    ;;
    restart)
    restart
    ;;
    status)
    status
    ;;
    quit)
    echo "$command is quit.."
    exit 0
    ;;
    *)
    Usage
    ;;
    esac

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

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

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

#!/bin/bash
username=login_user
login(){
 if who | grep $username;then
  echo "$username is login.."
  return 0
 else
  echo "$username is not login.."
  return 2
 fi
}
while true
do
 login
 result=$? 
 [ $result -eq 0 ] && break || sleep 3 
done

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

cpu) display cpu info

mem) display memory info

disk) display disk info

quit) quit

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

#!/bin/bash
cpu(){
 cat /proc/cpuinfo
}
mem(){
 free -m
}
disk(){
 fdisk -l 
}
quit(){
 echo "`basename $0` is quitting.."
 return 0
}
Usage(){
 echo "Usage: `basename $0` {cpu|mem|disk|quit}"
 return 2
}
echo -e " cpu) display cpu info \n
mem) display memory info \n
disk) display disk info \n
quit) quit"
while true 
read -p "please choose above option: " option
do
case $option in 
cpu)
 cpu 
break
;;
mem)
 mem
break
;;
disk)
disk
break
;;
quit)
quit
break
;;
*)
Usage
;;
esac
done

7、写一个脚本

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

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

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

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

#!/bin/bash
user(){
 id -u $1 &> /dev/null && uid=`id -u $1` || usage
 echo "$1 uid is   $uid"
 _shell=`grep "^$1" /etc/passwd | awk -F: '{print $NF}'`
 echo "$1  shell is   $_shell"
 exit 0
}
usage(){
 echo "your choose option is not a exits user.."
 return 2
}
echo "This programe is display UID and SHELL .."
while true 
do
read -p "please enter your choose or quit {USER|quit}: " options
case $options in
quit)
 echo "this programe is exitting.."
 exit 0
;;
*)
 user $options
;;
esac
done

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

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

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

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

此题的答案是第二题的第6个步骤,参照上面的答案即可。

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

(0)
luobo3692003luobo3692003
上一篇 2017-01-22
下一篇 2017-01-23

相关推荐

  • Linux简单的磁盘分区、格式化和挂载

     一.分区: 1.查看分区fdisk -l 通过fdisk -l 查看机器所挂硬盘个数及分区情况   2.通过上面的信息,我们知道此机器中挂载两个硬盘分别是:/dev/sda和/dev/sdb, 其中sda有两个主分区/dev/sda1和sda2; 其中sdb有1个扩展类型/dev/sdb3和3个逻辑分区sd…

    Linux干货 2016-02-28
  • llinux常用命令及bash基本特性

    一、常用的文件和目录管理命令 1. pwd命令:用来显示当前的工作目录 语法格式:直接输入pwd回车显示当前的工作目录 示例:用pwd命令显示当前的工作目录 [root@suyiwen ~]# pwd /root 2. mkdir命令:用来创建目录文件 语法格式:mkdir [OPTION]… DIRECTORY…常用option: -m,用来指定目录的权限…

    Linux干货 2018-03-11
  • 新鲜出炉的一篇好PPT,MySQL Optimizer团队力作

    新鲜出炉的一篇好PPT,MySQL Optimizer团队Senior Principal Software Engineer Øystein同学亲自操刀完成的《How to Analyze and Tune MySQL Queries for Better Performance》内容值得期待,有实现分析,有实战用例。有需要的朋友可以点击下载! 下载地址:…

    Linux干货 2015-02-27
  • 在CentOS5,6上破解和加密口令

    在CentOS5,6上:    破解和加密口令:     破解口令方法一: 破解口令方法二:    重启虚拟机进入救援模式: 备注:生产中不用虚拟机时不要挂载光盘;防止光盘引导破解密码 加密口令: 编辑配置文件: /etc/grub.conf

    2017-05-16
  • varnish浅述

    安装varnish,安装包需要到官网下载http://www.varnish-cache.org/releases/index.html varnish的程序环境: /etc/varnish/varnish.params:配置varnish服务进程的工作特性,例如监听的地址、端口及缓存机制等; /etc/varnish/default.vcl:配置各Chil…

    2016-11-15
  • Redis基于Sentinel哨兵高可用方案

    下载最新redis版本,当前最新版本为  2.8.19  2014-12-30 安装redis 首页地址:http://redis.io/ 最新稳定版下载地址: http://download.redis.io/releases/redis-2.8.19.tar.gz # tar -xvf redis-2.8.19.tar.gz # cd…

    2015-03-03

评论列表(1条)

  • 马哥教育
    马哥教育 2017-02-17 10:05

    写的很好,画图可以更好的理解问题,最好不要截屏上来,注意一下上半部分的排版,加油