马哥教育网络第21期-第十周课程练习

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

1.post加电自检,bios检测基础硬件设备
2.boot sequence:按次序查找各引导设备,第一个有引导程序的设备即为本次启动用到设备;读取启动设备MBR中
的bootloader,启动GRUB,选择内核加载到内存中。
3.kernel:自身初始化:探测可识别到的所有硬件设备;加载硬件驱动程序;(有可能会借助于ramdisk加载驱动)
以只读方式挂载根文件系统;运行用户空间的第一个应用程序:/sbin/init
4.运行/sbin/init:设置默认运行级别/etc/inittab 运行系统初始脚本/etc/rc.d/rc.sysinit完成系统初始化,
关闭对应下需要关闭的服务,启动需要启动服务/etc/rc.d/init.d,设置登录终端 
系统初始化:
POST --> BootSequence (BIOS) --> Bootloader(MBR) --> kernel(ramdisk) --> rootfs(只读) --> init

2、为运行于虚拟机上的CentOS 6添加一块新硬件,提供两个主分区;
  (1) 为硬盘新建两个主分区;并为其安装grub;
  (2) 为硬盘的第一个主分区提供内核和ramdisk文件; 为第二个分区提供rootfs;
  (3) 为rootfs提供bash、ls、cat程序及所依赖的库文件;
  (4) 为grub提供配置文件;
  (5) 将新的硬盘设置为第一启动项并能够正常启动目标主机;
(1)
    [root@node1 ~]# fdisk -l /dev/sdb

    Disk /dev/sdb: 21.5 GB, 21474836480 bytes
    255 heads, 63 sectors/track, 2610 cylinders
    Units = cylinders of 16065 * 512 = 8225280 bytes
    Sector size (logical/physical): 512 bytes / 512 bytes
    I/O size (minimum/optimal): 512 bytes / 512 bytes
    Disk identifier: 0xf34d70c0
    
       Device Boot      Start         End      Blocks   Id  System
    /dev/sdb1               1        1000     8032468+  83  Linux
    /dev/sdb2            1001        2610    12932325   83  Linux
    [root@node1 ~]# partx -a /dev/sdb
    [root@node1 ~]# mkfs.ext4 /dev/sdb1
    [root@node1 ~]# mkfs.ext4 /dev/sdb2
    [root@node1 /]# mkdir -p /mnt/{ramdisk,rootfs}
    [root@node1 /]# mount /dev/sdb1 /mnt/ramdisk/
    [root@node1 /]# mount /dev/sdb1 /mnt/rootfs/
    [root@node1 /]# grub-install --root-directory=/mnt /dev/sdb
(2)
        [root@node1 boot]# cp /boot/vmlinuz-2.6.32-642.1.1.el6.x86_64 /mnt/ramdisk/
        [root@node1 boot]# cp /boot/initramfs-2.6.32-642.1.1.el6.x86_64.img /mnt/rootfs/
(3)
        [root@node1 boot]# mkdir -p /mnt/rootfs/{bin,lib,lib64}
        [root@node1 boot]# cp -r /bin/bash /mnt/rootfs/bin
        [root@node1 boot]# cp $(ldd /bin/bash | awk '$3~/^\lib64/{printf $3}') /mnt/rootfs/
(4)
        default=0
        timeout=5
        splashimage=(hd0,0)/grub/splash.xpm.gz
        hiddenmenu
        title CentOS (2.6.32-642.6.2.el6.x86_64)
        root (hd0,0)
        kernel /vmlinuz-2.6.32-642.6.2.el6.x86_64 ro root=/dev/sdb1 selinux=0 init=/bin/bash
        initrd /initramfs-2.6.32-642.6.2.el6.x86_64.img
3、制作一个kickstart文件以及一个引导镜像。描述其过程。
yum -y install system-config-kickstart
[root@centos6 ~]# cat ks.cfg 
#platform=x86, AMD64, 或 Intel EM64T
#version=DEVEL
# Firewall configuration
firewall --disabled
# Install OS instead of upgrade
install
# Use NFS installation media
nfs --server=192.168.1.114 --dir=/mnt
key 123456
# Root password
rootpw --iscrypted $1$lYPG.hOy$UL8JxMVjmQeMp4018XIPn1
# System authorization information
auth  --useshadow  --passalgo=sha512
# Use graphical install
graphical
firstboot --disable
# System keyboard
keyboard us

[root@centos6 ~]# mkdir -p /tmp/myiso/isolinux
[root@centos6 ~]# cp /media/isolinux/* /tmp/myiso/isolinux/
[root@centos6 ~]# mkisofs -R -J -T -v –no-emul-boot –boot-load-size 4 –boot-info-table -V "CentOS
 6.8 x86_64 boo-b /tmp/myiso/isolinux/isolinux.bin -c /tmp/myiso/isolinux/boot.cat -o /root/boot.iso 
 myiso


4、写一个脚本
  (1) 能接受四个参数:start, stop, restart, status
   start: 输出“starting 脚本名 finished.”
   ...
  (2) 其它任意参数,均报错退出;
  
#!/bin/bash
if [ $# -eq 0 ];then
	echo "input argu"
	exit 1
fi
case $1 in
	start)
		echo "starting finished";;
	stop)
		echo "stoping finished";;
	restart)
		echo "restart finished";;
	*)
		exit 2
esac
  
5、写一个脚本,判断给定的用户是否登录了当前系统;
  (1) 如果登录了,则显示用户登录,脚本终止;
  (2) 每3秒钟,查看一次用户是否登录;

#!/bin/bash
if [ $# -eq 0 ];then
	echo "input argu"
	exit 1
fi
while [ 0 ];do
    if `w | grep "^$1\>" &> /dev/null`;then
        echo  "$1 is login"
        exit 2
    else
        sleep 3
    fi
done

6、写一个脚本,显示用户选定要查看的信息;
   cpu) display cpu info
   mem) display memory info
   disk) display disk info
   quit) quit
   非此四项选择,则提示错误,并要求用户重新选择,只到其给出正确的选择为止;
   
#!/bin/bash
if [ $# -eq 0 ];then
	echo "input argu"
	exit 1
fi
while [ 0 ];do
	case $1 in
		cpu)
			lscpu;;
		mem)
			cat /proc/meminfo;;
		disk)
			fidsk -l;;
		*)
			echo "error"
			continue;;
		quit)
			exit 1;;
	esac
done

7、写一个脚本
  (1) 用函数实现返回一个用户的UID和SHELL;用户名通过参数传递而来;
  (2) 提示用户输入一个用户名或输入“quit”退出;
    当输入的是用户名,则调用函数显示用户信息;
    当用户输入quit,则退出脚本;进一步地:显示键入的用户相关信息后,再次提醒输出用户名或quit: 
 
#!/bin/bash
while [ 0 ];do
	read -p " input user:" username
	if [ $username == "quit" ];then
		exit 2
	else
		userinfo $username 
	fi
done

userinfo {
	if `id $username &> /dev/null`;then
		echo "uid: `id -u $username`"
		echo "shell: `grep '^$username' /etc/passwd | cut -d: -f7`"
	else
		echo "error"
	fi	
		 
}

8、写一个脚本,完成如下功能(使用函数)
   (1) 提示用户输入一个可执行命令的名字;获取此命令依赖的所有库文件;
   (2) 复制命令文件至/mnt/sysroot目录下的对应的rootfs的路径上,例如,如果复制的文件原路径是/usr/bin/useradd,则复制到/mnt/sysroot/usr/bin/目录中;
   (3) 复制此命令依赖的各库文件至/mnt/sysroot目录下的对应的rootfs的路径上;规则同上面命令相关的要求;
   
#!/bin/bash
read -p " input argu: " comd
path=$(which $comd)
lib=$(ldd $path | egrep -o "[^[:space:]]+")

comcp $comd
libcp $comd

comcp {
	cp $path /mnt/sysroot$path	
}

libcp {
	for i in $lib;do
		cp $i /mnt/sysroot$path
	done
}

以上

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

(0)
上一篇 2016-11-14 08:28
下一篇 2016-11-14 08:29

相关推荐

  • Linux中软链接和硬链接的区别

    Linux中软链接和硬链接的区别 链接文件:   Linux中包括两种链接:硬链接(Hard Link)和软链接(Soft Link),软链接又称为符号链接(Symbolic link)。 Inode 文件除了纯数据本身之外,还必须包含有对这些纯数据的管理信息 文件名; 访问权限; 文件的属主以; 该文件的数据所对应的磁盘数据块; 文件的时间戳; …

    Linux干货 2016-10-20
  • 高级文件系统的管理

    接上一篇文章http://www.178linux.com/40874 移动介质     挂载意味着 使外来的文件系统看起来如同是主目录树 的 一部分     访问前、介质必须被挂载     摘除时,介质必须被卸载   …

    Linux干货 2016-09-08
  • 第五周 练习

    1、显示当前系统上root、fedora或user1用户的默认shell; 1.  egrep "^(root|user1|fedora)" /etc/passwd|cut –d: –f7   2、找出/etc/rc.d/init.d/functions文件中某单词后面跟一组小括号的行,形如:h…

    Linux干货 2016-11-28
  • 文件系统管理&raid&脚本编程之参数、算数运算练习

    1、创建一个10G分区,并格式为ext4文件系统; (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl; (2) 挂载至/data/mydata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳; (1) ~]# fdisk /dev/sdb Welcome to…

    Linux干货 2016-11-08
  • 20161021第6天作业

    20161021第6天作业 1、将PATH变量每个目录显示在独立的一行  echo "$PATH" |tr ':' '\n' 2、将指定文件中0-9分别替代成a-j tr '0-9' 'a-j' <文件 3、将文件中每个单词(由字母组成)显示在…

    Linux干货 2016-10-23
  • scp命令

    scp命令: 基于ssh连接完成复制   scp  [options]  SRC…  DEST/ scp  [options]  SRC  DEST   存在两种使用情形: PULL获取:  scp  [options]  [user@]host:/PATH/TO/SOMEFILE   /PATH/TO/SOMEFILE PU…

    Linux干货 2017-10-21

评论列表(1条)

  • 马哥教育
    马哥教育 2016-11-16 15:54

    写的很好,就是排版可能需要修改一下,继续加油