网络21期第十周博客作业

网络21期第十周博客作业

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/

#配置grubvim /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 instart)
        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 $userdone

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/45377

(0)
上一篇 2016-09-15 22:21
下一篇 2016-09-15 22:22

相关推荐

  • Linux软件包管理之rpm和yum的使用

    rpm命令的使用 什么是RPM? rpm:RPM Package Manager (原Redhat Package Manager) Linux 软件包管理工具 特定的程序由应用程序组成;     GPL:源码     glibs:标准的C库 常见Linux发行版的软件包管理器:…

    Linux干货 2016-08-25
  • Linux的哲学思想

    Linux的哲学思想 一切皆文件 不管是普通的文件、目录,还是跟硬件相关的字符设备、块设备、套接字等在Linux中都被当作文件来进行统一的操作管理。 单个程序完成简单的功能,复杂的功能由多个程序组合而成 单个程序只实现简单功能,保证了其高效运行,而复杂功能由多个简单程序组合而成,也能保证一定的高效性。 尽量避免与用户交互 程序从启动开始到结束不需要用户参与,…

    Linux干货 2017-07-02
  • 第三周

    第三周 1.列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@node1 ~]# who -q | sed -n ‘1p’ centos root fedora redhat mint 2.取出最后登录到当前系统的用户的相关信息。 [root@node1 ~]# who -a | tail -1 mint +…

    Linux干货 2017-07-25
  • 逻辑卷的创建与移除

    一、弹性控制磁盘大小的lvm:     假如有这样一个场景,在初始安装linux系统时给 /home分区设置了一定大小,但是过了一段时间后,你发现初始分配的大小远不能满足公司的扩大,员工增加,需要分配的账号的磁盘空间也变大,这时你应该怎么办?是挂载一块更大的硬盘,将原来的小硬盘拆除掉吗?其实在linux中有lvm可动态增大文件系…

    Linux干货 2016-08-30
  • 文件系统管理和挂载

    磁盘结构 设备类型:     块设备:block,存取单位“块”,例如,磁盘     字符设备:char,存取单位“字符”,键盘 设备文件:关联至一个设备驱动程序,进而能够跟之对应硬件设备进行通信 设备号码:     主设备号:major …

    Linux干货 2016-08-29
  • 马哥教育网络20期+第六周课程练习

    请详细总结vim编辑器的使用并完成以下练习题 1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#; :%s/^[[:space:]]/#&/ 2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白…

    Linux干货 2016-07-07