網絡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/

#配置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.www58058.com/45722

(0)
N21_志建N21_志建
上一篇 2016-09-15
下一篇 2016-09-15

相關推薦

  • 軟件包管理

    一、軟件運行環境     API: Application Programming Interface         POSIX: Portable OS     程序源代碼 –>…

    Linux干貨 2016-08-22
  • DNS and Bind

    DNS and Bind      DNS服務器所提供的服務是完成將主機名和轉換為IP地址的工作。為什么需要將主機名轉換為IP地址的工作呢?這是因為,當網絡上的一臺客戶機訪問某一服務器上的資源時,用戶在瀏覽器地址欄中輸入的是人類便于識記的主機名和域名。而網絡上的計算機之間實現連接卻是通過每臺計算機在網絡中擁有的惟一的IP地址來完…

    Linux干貨 2017-06-01
  • 馬哥教育網絡班21第五周練習作業

    1、顯示/boot/grub/grub.conf中以至少一個空白字符開頭的行; [root@localhost ~]# grep "^[[:space:]]\+" /boot/grub2/grub.cfg   2、顯示/etc/rc.d/rc.sysinit文件中以#開頭,后面跟至少一個空…

    Linux干貨 2016-08-08
  • Linux任務計劃、周期性執行任務

    Linux任務計劃、周期性執行任務 在未來指定的時間點執行一次某任務:at、batch 周期性的執行某個任務:crontab執行結果會以郵件形式發送給用戶 如何查看郵件服務是否啟用~ ]# ss -tnl mail 命令: mail [-s ‘郵件名’]+ USERNAME 郵件文件的生成: (1) 交互式輸入: ctrl+d結束或者 以 . 單獨成行 (2…

    Linux干貨 2017-08-16
  • 【linux】正則表達式之grep、egrep、元字符

    正則表達式:     又稱正規表示法、常規表示法(英語:Regular Expression,在代碼中常簡寫為regex、regexp或RE),計算機科學的一個概念。是一類字符所書寫的模式,其中許多字符(元字符)不表示其字面意義,而是表達控制或通配等功能。正則表達式使用單個字符串來描述、匹配一系列符合某個句法規則的字符…

    Linux干貨 2015-04-01
  • Linux中的文件和目錄的權限管理

    Linux系統通過完善的權限管理來限制每一個用戶對于系統中文檔和目錄的訪問。在Linux系統中,文件和目錄的權限是有些差異的。一、權限介紹:如上所示,通過ll命令列出目錄下文件的時候同時也會列出文件的權限,從第二位開始,一直到第九位,即rw-r–r–就是文件的權限描述:其中3位為一組:第一組:rw-:代表文件的屬主(user)對文件的…

    Linux干貨 2017-04-01

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-09-19 17:33

    寫的很好,最好一個是不是還缺少點判斷條件?

欧美性久久久久