要求如下:
寫一個shell腳本:
1、創建一個函數,可以接受一個磁盤設備路徑(如/dev/sdb)作為參數;在真正開始後面步驟之前提醒用戶有危險,並讓用戶選擇是否繼續;
而後將此磁盤設備上的所有分區清空(提示,使用命令dd if=/dev/zero of=/dev/sdb bs=512 count=1實現,注意其中的設備路徑不要寫錯了);如果此步驟失敗,返回67給主程序;
接著在此磁盤設備上創建兩個主分區,一個大小為100M,一個大小為1G;如果此步驟失敗,返回68給主程序;
格式化此兩分區,文件系統類型為ext3;如果此步驟失敗,返回69給主程序;
如果上述過程都正常,返回0給主程序;
2、調用此函數;並通過接收函數執行的返回值來判斷其執行情況,並將信息顯示出來;
代碼如下:
- #!/bin/bash
- #Author: MOS
- #Script name: funPart.sh
- #Date & Time: 2012-10-10/12:20:53
- #Version: 1.0.1
- #Description:
- #
- Disk_Mod(){
- #使用if匹配模式,使用for循環判斷是否存在,如果有,則取其絕對路徑,跳出循環,如果不匹配或文件不存在,跳出函數,返回66
- if [[ -n $1 && $1 =~ "/dev/sd[a-z]" ]];then
- local Darray=(`ls /dev/sd[a-z]`)
- for i in ${Darray[*]};do
- [[ "$i" == "$1" ]] && Sd=$i && break
- done
- else
- return 66
- fi
- #當匹配成功,進入選擇,告訴用戶,是否繼續,輸錯的話進入無限循環,當用戶選擇Y,則清空目標分區,且跳出while循環
- while :;do
- read -p "Warning!!!This operation will clean $Sd data. Next=y,Quit=n [y|n]: " Choice
- case $Choice in
- y)
- dd if=/dev/zero of=$Sd bs=512 count=1 &> /dev/null && break || return 67 ;;
- n)
- exit 88 ;;
- *)
- echo "Invalid choice,please choice again." ;;
- esac
- done
- #使用echo傳遞給fdisk進行分區,如果此命令失敗,則跳轉出去,錯誤值68,需要注意的是,有時候這個返回值很詭異,筆者之前成功與否都是返回的1,後來重啟之後,就好了,如果慎重的話,可以對創建的分區,進行判斷,不過就需要使用其他工具截取相關字段了,雖有些小麻煩,但無大礙
- echo -e "n\np\n1\n\n+100M\nn\np\n2\n\n+1024M\nw\n"|fdisk /dev/sdb &> /dev/null || return 68
- #格式化之前,讓內核重新讀取磁盤分區表,值得注意的是,有的系統版本,使用partprobe無效,譬如筆者的環境是rhel5.8,而rhel6.0以後,這個命令就很危險了,而使用partx -a /dev/sdb則效果更好...此項需慎重,如果格式化失敗,則告知把失敗的分區定義成變量,且跳出函數,並帶出錯誤值69
- `partprobe`
- Part=`fdisk -l /dev/$Sd|tail -2|cut -d" " -f1`
- for M in ${Part[*]};do
- ! mke2fs -j $M &> /dev/null && ErrorPart=$M && return 69
- done
- return 0
- }
- #下面代碼,調用函數,接收函數返回值,根據返回值進行判斷哪裡出錯。
- Disk_Mod $1
- Res=$?
- [ $Res -eq 0 ] && exit 0
- [ $Res -eq 66 ] && echo "Error! Invalid input."
- [ $Res -eq 67 ] && echo "Error! Command -> dd <- Faild."
- [ $Res -eq 68 ] && echo "Error! Command -> fdisk <- Faild."
- [ $Res -eq 69 ] && echo "Error! Command -> mke2fs <- Faild."