22期第十周課堂練習

1、請詳細描述CentOS系統的啟動流程(詳細到每個過程系統做了哪些事情)

Centos啟動過程 .png

    2、為運行于虛擬機上的CentOS 6添加一塊新硬件,提供兩個主分區;
      (1) 為硬盤新建兩個主分區;并為其安裝grub;
      (2) 為硬盤的第一個主分區提供內核和ramdisk文件;   為第二個分區提供rootfs;
      (3)   為rootfs提供bash、ls、cat程序及所依賴的庫文件;
      (4) 為grub提供配置文件;

      (5) 將新的硬盤設置為第一啟動項并能夠正常啟動目標主機;

1.創建2個主分區,sdb1,sdb2
[root@bogon ~]# fdisk -l /dev/sdb

Disk /dev/sdb: 11.8 GB, 11811160064 bytes
255 heads, 63 sectors/track, 1435 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: 0xa5b8f2f4

   Device Boot      Start         End      Blocks   Id  System
/dev/sdb1               1         654     5253223+  83  Linux
/dev/sdb2             655        1308     5253255   83  Linux
2.格式化分區,格式為ext4
[root@bogon ~]# mke2fs -t ext4 /dev/sdb{1,2}
3.掛載分區sdb1到/mnt下
[root@bogon ~]# mount /dev/sdb1  /mnt/boot
4.安裝grub到sdb1上
[root@bogon ~]# grub-install  --root-directory=/mnt /dev/sdb
Probing devices to guess BIOS drives. This may take a long time.
Installation finished. No error reported.
This is the contents of the device map /mnt/boot/grub/device.map.
Check if this is correct or not. If any of the lines is incorrect,
fix it and re-run the script `grub-install'.

(fd0)	/dev/fd0
(hd0)	/dev/sda
(hd1)	/dev/sdb
5.復制內核及ramdisk文件到sdb1上
[root@bogon ~]# cp /boot/initramfs-2.6.32-431.el6.x86_64.img  /mnt/boot/initramfs.img
[root@bogon ~]# cp /boot/vmlinuz-2.6.32-431.el6.x86_64 /mnt/boot/vmlinuz
6.編輯grub.conf文件,/mnt/boot/grub/grub.conf
[root@bogon grub]# vim grub.conf
default=0
timeout=5
title CentOS6(test)
root (hd0,0)
kernel /vmlinuz ro root=/dev/sda2 selinux=0 init=/bin/bash
initrd /initramfs.img
7.卸載/mnt目錄
[root@bogon /]# umount /mnt
8.掛載分區/dev/sdb2到/mnt下
[root@bogon /]# mount /dev/sdb2 /mnt/sysroot
9.創建系統必須的目錄
[root@bogon mnt]# mkdir -p /mnt/sysroot{bin,dev,etc/{rc.d/init.d,sysconfig/network-scripts},lib/modules,lib64,proc,sbin,sys,tmp,usr/local/{bin,sbin},var/{lock,log,run}}
10.拷貝命令的到/mnt下
[root@bogon boot]# cp /bin/{bash,ls,cat} /mnt/bin/
10.拷貝命令的依賴文件
[root@bogon boot]# cp `ldd /bin/{bash,ls,cat}  |grep -oe "/lib.*[[:space:]]"|sort -u` /mnt/lib64/
12.測試并同步
[root@bogon boot]# chroot /mnt/sysroot
bash-4.1# ls
bin  boot  dev	etc  lib  lib64  lost+found  proc  sbin  sys  tmp  usr	var
bash-4.1# ls
bin  boot  dev	etc  lib  lib64  lost+found  proc  sbin  sys  tmp  usr	var
bash-4.1# cat bin
cat: bin: Is a directory
bash-4.1# cd bin 
bash-4.1# ls
bash  cat  ls
bash-4.1# exit
exit
[root@bogon boot]# sync
13.重啟后,將這塊硬盤添加到新創建的虛擬機做引導盤

    3、制作一個kickstart文件以及一個引導鏡像。描述其過程。

可以直接手動編輯或使用工具在桌面模式下用system-config-kickstart(centos6.x)來創建ks.cfg
#命令段
firewall --disabled//禁用防火墻
install//執行新安裝
cdrom//用光盤安裝
lang en_US.UTF-8//默認安裝語言
keyboard us//選擇鍵盤
rootpw --iscrypted $1$gWoGuWzn$E7polUWsUlS6qPXzQryRm //管理員密碼
authconfig --enableshadow --passalgo=sha512
selinux --enforcing//激活selinux
logging --level=info//信息等級
timezone --utc Asia/Shanghai//系統時區
bootloader --location=mbr --driveorder=sdb --append="crashkernel=auto rhgb quiet"
clearpart --all//刪除所有現在分區
part /boot --fstype=ext4 --size=500//分區掛載
part / --fstype=ext4 --size=20480
part swap --size=4096
#腳本段
%pre//安裝前腳本
echo "start install"
%end
%post//安裝后腳本
echo "install end"
#程序包段
%packages
@chinese-support//中文支持
@development//開發工具
@graphical-desktop-clients//圖形化工具
@remote-desktop-clients//遠程桌面客戶端
%end
簡單引導鏡像光盤制作:
1)復制系統安裝光盤除Packages和repodata外的所有目錄下的所有文件到一自定義目錄(/centos6.5)
mount -r /dev/cdrom /mnt/
mkdir /centos6.5
cp -arf /mnt/{CentOS_BuildTag,isolinux,R*,E*,GPL,T*,images} /centos6.5/
cd /centos6.6/
2)創建引導光盤:把/centos6.5目錄創建為光盤鏡像boot.iso
mkisofs -R -J -T -v --no-emul-boot --boot-load-size 4 --boot-info-table -V 
 "CentOS 6.5 x86_64 boot" -b isolinux/isolinux.bin -c isolinux/boot.cat 
  -o /root/boot.iso /centos6.5/
簡單自動安裝系統光盤制作
1)復制安裝系統光盤的所有目錄下的所有文件和ks.cfg文件到一自制目錄(/centos6.5)
cd /centos6.6/
cp -r /mnt/* .
cp /root/ks.cfg .
2)在/centos6.5/isolinux/isolinux.cfg文件中append initrd=initrd.img條目中添加ks文件讀取路徑 ks=cdrom:/ks.cfg
3)創建引導光盤:把centos6.5目錄創建為光盤鏡像centos.iso 
mkisofs -R -J -T -v --no-emul-boot --boot-load-size 4 --boot-info-table 
 -V "CentOS 6.5 x86_64 boot"  -b isolinux/isolinux.bin -c isolinux/boot.cat 
 -o /root/boot.iso /centos6.5

    4、寫一個腳本
      (1) 能接受四個參數:start, stop, restart,   status
       start: 輸出“starting 腳本名   finished.”
       …

      (2) 其它任意參數,均報錯退出;

#!/bin/bash
case $1 in
start)
echo "start script finished "
;;
stop)
echo "stop script stop"
;;
restart)
echo "restart script restart"
;;
*)
echo "unknow"
;;
esac

    5、寫一個腳本,判斷給定的用戶是否登錄了當前系統;
      (1) 如果登錄了,則顯示用戶登錄,腳本終止;

      (2) 每3秒鐘,查看一次用戶是否登錄;

#!/bin/bash
while true;do
if who | grep "^user1\>" &> /dev/null;then
    echo "user1 login"  
   break
fi
 sleep 3
done

    6、寫一個腳本,顯示用戶選定要查看的信息;
       cpu) display cpu info
       mem) display memory info
       disk) display disk info
       quit) quit

         非此四項選擇,則提示錯誤,并要求用戶重新選擇,只到其給出正確的選擇為止;

#!/bin/bash
cat << EOR
cpu) display cpu info
mem) display memory info
disk) diskplay disk info
quit) quit
EOR
read -p  "your choice:" i

while [ "$i" != "cpu" -a "$i" != "mem" -a "$i" != "disk" -a "$i" != "quit" ]; do
echo "cpu, mem, disk, quit"
read -p "Enter your option again: " i
done

case $i in
cpu)
    lscpu
;;
men)
 free -m
;;
disk)
 fdisk -l /dev/[hs]d[a-z]
;;
quit)

    7、寫一個腳本
      (1)   用函數實現返回一個用戶的UID和SHELL;用戶名通過參數傳遞而來;
      (2) 提示用戶輸入一個用戶名或輸入“quit”退出;
        當輸入的是用戶名,則調用函數顯示用戶信息;

          當用戶輸入quit,則退出腳本;進一步地:顯示鍵入的用戶相關信息后,再次提醒輸出用戶名或quit:

#!/bin/bash
cat << EOR
user) show user uid and shell
quit) quit
EOR


while true; do
read -p "Please input username or quit:"  username
  if id $username &> /dev/null; then
   uid=`cat /etc/passwd |grep "^$username\>"|cut -d: -f3`
   shell=`cat /etc/passwd |grep "$username\>"|cut -d: -f7`
   echo "userid is:" $uid
   echo "usershell is:" $shell
   continue
   elif [ $username == quit ];then
    exit 0
   else
    echo "ERROR option"
   fi
done

     8、寫一個腳本,完成如下功能(使用函數)
       (1)   提示用戶輸入一個可執行命令的名字;獲取此命令依賴的所有庫文件;
       (2)   復制命令文件至/mnt/sysroot目錄下的對應的rootfs的路徑上,例如,如果復制的文件原路徑是/usr/bin/useradd,則復制到/mnt/sysroot/usr/bin/目錄中;

       (3)   復制此命令依賴的各庫文件至/mnt/sysroot目錄下的對應的rootfs的路徑上;規則同上面命令相關的要求;

#!/bin/bash
read -p "input a common:"  common
      a=`which $common`
      b=`ldd $a |grep -oe "/[^[:space:]]*"`
      cpfile(){
          cp  $a  /mnt/sysroot$a
        for i in `ldd $a |grep -oe "/[^[:space:]]*"`;do
          cp $i  /mnt/sysroot$i
          echo "copy finshed"
        done
      }
 cpfile

原創文章,作者:a295053193,如若轉載,請注明出處:http://www.www58058.com/52332

(0)
a295053193a295053193
上一篇 2016-10-24
下一篇 2016-10-24

相關推薦

  • 優云軟件:雙態運維下,老司機是怎么玩CMDB的?

    行業內有個科技公司,CMDB前后建設12年,重構了N次,一言不合就重構,我深深的被這種屢拆屢戰,初心不改精神所折服。我真心想問下做CMDB的兄弟,各位是怎么熬過來的?請不要回避,其實我們都曾被這樣虐過! 近幾年我司承建國內很多傳統行業的CMDB項目,坦白的說,隨著互聯網+熱潮的沖擊,因很多傳統企業也慢慢的在轉變業務,把很多傳統型的業務互聯網化,或者開辟新型業…

    2016-08-05
  • 廣域網中的DNS服務

    拓撲圖                      創建主DNS:     配置文件/etc/named.conf&nbs…

    2017-04-15
  • Linux Sysadmin–part2

    1、寫一個腳本,使用ping命令探測192.168.4.1-192.168.4.254之間的所有主機的在線狀態; 在線的主機使用綠色顯示; 不在線的主使用紅色顯示; #!/bin/bash #description: #date: #Author: for i in {1..254}; do if ping -c 3 192.168.4.$i &&g…

    2017-09-19
  • keepalived雙主模型的實現

    一、簡介  keepalived 簡介:是服務器高可用的一個重要軟件,它的核心組件有vrrp ,stack, checker ,ipvs, warpper, watch dog  它是vrrp協議的實現,原生設計目的為高可用ipvs服務;keepalived能夠通過配置文件中定義生成ipvs規則 并能夠對RS的健康狀態進行檢測;vrrp_…

    Linux干貨 2016-08-30
  • 文件系統初步了解

    Linux文件系統的基礎特性: 1文件名嚴格區分大小寫 2所有文件都們于根目錄下,FHS 3路徑以/做為分隔符 4每個文件的名稱可使用除/以外任意字符,單個名稱最長不能超出255個字 FHS:Filesystem Hierarchy Standard(文件系統目錄標準)的縮寫 多數Linux版本采用這種文件組織形式,類似于Windows操作系統中c盤的文件目…

    Linux干貨 2015-04-27
  • N25-第四周博客

      復制/etc/ske1目錄為/home/tuser1,要求/home/tuser1及其內部文件的屬組合其他用戶均沒有任何訪問權限。            2,編輯/etc/group文件,添加組hadoop.。    &nbs…

    Linux干貨 2016-12-22

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-11-02 14:35

    博客寫得非常的好,32個贊,給出了詳細操作步驟,腳本思路清晰,排版需要注意一下哈,加油!

欧美性久久久久