1、请详细描述CentOS系统的启动流程(详细到每个过程系统做了哪些事情)
Centos6启动流程: POST加电自检 ---> BOOT Sequence ---> 加载内核启动系统 (1)POST加电自检: 对每一个设备进行检查。寻找引导记录,并把控制权交由引导记录。 (2)BOOT Sequence:MBR、GRUB MBR:记录磁盘扇区,共512个字节,前446个字节是BootLoder,后4*16的64个字节是存放分区信息的,最后2个字节是校验信息,一般是 55AA GRUB:MBR中的前446个字节,它的作用是要选择要启动的内核。 (3)加载内核启动系统 kernel初始化:探测可识别的所有硬件设备;加载硬件驱动;以只读方式挂载根文件系统;运行用户控件的第一个应用程序:/sbin/init
2、为运行于虚拟机上的CentOS 6添加一块新硬件,提供两个主分区;
(1) 为硬盘新建两个主分区;并为其安装grub;
(2) 为硬盘的第一个主分区提供内核和ramdisk文件; 为第二个分区提供rootfs;
(3) 为rootfs提供bash、ls、cat程序及所依赖的库文件;
(4) 为grub提供配置文件;
(5) 将新的硬盘设置为第一启动项并能够正常启动目标主机;
#创建主分区分区 [root@caizhijian ~]# fdisk /dev/sdb Command (m for help): p Disk /dev/sdb: 10.7 GB, 10737418240 bytes 255 heads, 63 sectors/track, 1305 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: 0xadcb7188 Device Boot Start End Blocks Id System /dev/sdb1 1 262 2104483+ 83 Linux /dev/sdb2 263 655 3156772+ 83 Linux Command (m for help): #通知内核重读硬盘分区 [root@caizhijian ~]# partx -a /dev/sdb #创建分区文件系统格式 [root@caizhijian ~]# mkfs.ext4 /dev/sdb1 [root@caizhijian ~]# mkfs.ext4 /dev/sdb2 #创建文件夹挂载分区 [root@caizhijian ~]# mkdir -pv /mnt/boot /mnt/sysroot [root@caizhijian ~]# mount /dev/sdb1 /mnt/boot/ [root@caizhijian ~]# mount /dev/sdb2 /mnt/sysroot/ (可用 ls /mnt/boot ; ls /mnt/sysroot 查看是否lost+found文件,有则说明挂载成功) [root@caizhijian ~]# cp -a /boot/vmlinuz-2.6.32-504.el6.x86_64 /mnt/boot/vmlinuz [root@caizhijian ~]# cp -a /boot/initramfs-2.6.32-504.el6.x86_64.img /mnt/boot/initramfs.img #安装grub [root@caizhijian ~]# grub-install --root-directory=/mnt /dev/sdb [root@caizhijian sysroot]# mkdir -pv etc bin sbin lib lib64 dev proc sys tmp var usr home root mnt media #复制bash; ls; cat;所依赖的库文件 [root@caizhijian sysroot]# mkdir -pv bin lib64 [root@caizhijian sysroot]# cp /bin/bash /bin/ls /bin/cat /mnt/sysroot/bin/ [root@caizhijian sysroot]# cp `ldd /bin/bash | sed '1d'| grep -Eo "/.*[0-9] "` /mnt/sysroot/lib64/ [root@caizhijian sysroot]# cp `ldd /bin/ls | sed '1d'| grep -Eo "/.*[0-9] "` /mnt/sysroot/lib64/ [root@caizhijian sysroot]# cp `ldd /bin/cat | sed '1d'| grep -Eo "/.*[0-9] "` /mnt/sysroot/lib64/ #配置grub vim /mnt/boot/grub/grub.conf default=0 timeout=5 title CentOS (Expres) root (hd0,0) kernel /vmlinuz ro root=/dev/sda2 selinux=0 init=/bin/bash initrd /initramfs.img 最后把sdb磁盘设置成第一启动项。
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: 指明安装源 3、创建kickstart文件的方式: (1) 直接手动编辑; 依据某模板修改; (2) 可使用创建工具:system-config-kickstart (CentOS 6) 依据某模板修改并生成新配置; 4、检查ks文件的语法错误:ksvalidator # ksvalidator /PATH/TO/KICKSTART_FILE 5、创建引导光盘: # 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 start(){ echo "starting $0 finished." } stop(){ echo "stop $0 finished." } restart(){ echo "restart $0 finished." } status(){ echo "status $0 finished." } usage(){ echo "please enter start|stop|restart|status" exit 1 } case $1 in start) start ;; stop) stop ;; restart) restart ;; status) status ;; *) usage ;; esac
5、写一个脚本,判断给定的用户是否登录了当前系统;
(1) 如果登录了,则显示用户登录,脚本终止;
(2) 每3秒钟,查看一次用户是否登录;
#!/bin/bash read -p "Enter a user name:" user while true; do if [ "$user" == `who | grep -o "^$user" | uniq` ]; then echo "$user logged." exit 0 else sleep 3 fi done
6、写一个脚本,显示用户选定要查看的信息;
cpu) display cpu info mem) display memory info disk) display disk info quit) quit
非此四项选择,则提示错误,并要求用户重新选择,只到其给出正确的选择为止;
#!/bin/bash cpu(){ cat /proc/cpuinfo } mem(){ cat /proc/meminfo } disk(){ fdisk -l | grep "[sh]d[a-z]"} quit(){ echo "quit" exit 0} usage (){ echo "Enter cpu|mem|disk|quit" exit 1} read -p "Enter a device:" device case $device in cpu) cpu ;; mem) mem ;; disk) disk ;; quit) quit ;; *) usage ;; esac
7、写一个脚本
(1) 用函数实现返回一个用户的UID和SHELL;用户名通过参数传递而来;
(2) 提示用户输入一个用户名或输入“quit”退出;
当输入的是用户名,则调用函数显示用户信息;
当用户输入quit,则退出脚本;进一步地:显示键入的用户相关信息后,再次提醒输出用户名或quit:
#!/bin/bash function userinfo { if id $user &> /dev/null;then echo "UID : `id -u $user`" echo "SHELL:`grep -E '^('$user')\>' /etc/passwd | cut -d: -f7`" read -p "Enter a username or quit:" userelse read -p "plsease again enter a username or quit:" userfi } read -p "Enter a username or quit:" user while [ "$user" != "quit" ];do userinfo $user done
8、写一个脚本,完成如下功能(使用函数)
(1) 提示用户输入一个可执行命令的名字;获取此命令依赖的所有库文件;
(2) 复制命令文件至/mnt/sysroot目录下的对应的rootfs的路径上,例如,如果复制的文件原路径是/usr/bin/useradd,则复制到/mnt/sysroot/usr/bin/目录中;
(3) 复制此命令依赖的各库文件至/mnt/sysroot目录下的对应的rootfs的路径上;规则同上面命令相关的要求;
#!/bin/bash read -p "Enter a commond:" cmd path=`which $cmd`cppath(){ cp $path /mnt/sysroot$path echo "copy $cmd path to /mnt/sysroot$path over." } cplib(){ lib=`ldd $path | grep -o "/[^[:space:]]\{1,\}"` for i in $lib; do cp $lib /mnt/sysroot$path echo "copy $cmd lib to /mnt/sysroot$path over." done } cppath cplib
原创文章,作者:N21_志建,如若转载,请注明出处:http://www.178linux.com/45722
评论列表(1条)
写的很好,最好一个是不是还缺少点判断条件?