加入收藏 | 设为首页 | 会员中心 | 我要投稿 佛山站长网 (https://www.0757zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 服务器 > 搭建环境 > Linux > 正文

使用shell脚本自动清空创建并格式化硬盘

发布时间:2016-11-02 08:12:43 所属栏目:Linux 来源:网络整理
导读:作业3: 要求如下: 写一个脚本: 1、创建一个函数,可以接受一个磁盘设备路径(如/dev/sdb)作为参数;在真正开始后面步骤之前提醒用户有危险,并让用户选择是

作业3:

要求如下:

写一个脚本:

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 "nnpn1nn+100Mnnnpn2nn+1024Mnwn"|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."

查看本栏目更多精彩内容:http://www.bianceng.cn/OS/Linux/

(编辑:佛山站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读