练习1.
写一个脚本,通过ping 命令测试192.168.0.100到192.168.0.254之间的所有主机是否在线,
如果在线,就显示“ip is up.”IP为真实IP地址,且以绿色显示;
如果不在线,就显示“IP is down." ,以红色显示
要求:分别使用while, until 和for循环实现。
.for循环
#/bin/bash
#
for i in {..};do
if ping 192.168..$i -c1 -w1 > /dev/null;then
echo -e "\033[32m192.168.3.$i IP is up\033[0m"
else
echo -e "\033[31m192.168.3.$i IP is down!\033[0m"
fi
done .while 循环
#/bin/bash
#
i=
while [ $i -le ];do
if ping -c1 -w1 192.168..$i &> /dev/null;then
echo -e "\033[32m192.168.3.$i IP is up.\033[0m"
else
echo -e "\033[31m192.168.3.$i IP is down.\033[0m"
fi
((i++))
done 注:ping -c1 一次
-w1 延迟一秒 颜色:
echo -e "\033[35mHello\033[0m,world."
练习2.
写一个脚本(前提:请为虚拟机新增一块硬盘,假设它为/dev/sdb),为指定的硬盘创建分区:
1.列出当前系统上所有的磁盘,让用户选择,如选择quit 则退出脚本:如果用户选择错误,就让用户重新选择;
2.当用户选择后,提醒用户确认接下来的操作可能会损坏数据,并请用户确认;如果用户选择y就继续,否则,让用户重新选择;
3.抹除那块硬盘上的所有分区(提示,抹除所有分区后执行sync命令,并让脚本睡眠3秒钟后再分区):并为其创建三个主分区,第一个为20M,第二个为512M,第三个为123M,且第三个为swap分区类型;(将分区命令通过echo传送给fdisk即可实现)
脚本分析: .删除分区: dd if=/dev/zero of=/dev/hda bs= count= dd 用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换 if= :输入文件名 of=: 输出文件名 bs : 指定读入/输出的块大小,字节 count:#块个数 用空字节覆盖MAR引导,既删除分区整个硬盘分区 将U盘当前状态保存下来成为一个文件。
dd if=/dev/sdb of=/backup/ISO/Upan/save.iso cat /dev/cdrom > xx.iso mkisofs -r -o xx.iso /dev/cdrom .取出硬盘列表: fdisk -l > /dev/null |grep "Disk /dev/[sh]d[a-z]" | awk -F: '{print $1}' .脚本创建分区 echo 'n n p +20M w' | fdisk /dev/hda [root@localhost test]# cat disk.sh
#!/bin/bash
#
echo "Initial a disk..."
echo -e "\033[31mWarning:\033[0m"
fdisk -l > /dev/null |grep -o "^Disk /dev/[sh]d[a-z]" read -p "Your choice:" PARTDISK if [ $PARTDISK == 'quit' ];then
echo "quit"
exit
fi until fdisk -l > /dev/null | grep -o "^Disk /dev/[sh]d[a-z]" | grep "^Disk $PARTDISK$" &> /dev/null;do
read -p "Wrong option,Yourchoice aging:" PARTDISK
done read -p "Will destroy all data, continue:y|n? " CHOICE until [ $CHOICE == 'y' -o $CHOICE == 'n' ];do
read -p "Will destroy all data,continue:y|n? " CHOICE
done
if [ $CHOICE == 'n' ];then
echo "quit"
exit
else
dd if=/dev/zero of=$PARTDISK bs= count=
sync
sleep
echo 'n
p +20M
n
p +512M
n
p +128M
t w' | fdisk $PARTDISK &> /dev/null partprobe $PARTDISK
sync
sleep
mkfs.ext4 ${PARTDISK}
mkfs.ext4 ${PARTDISK}
mkswap ${PARTDISK}
fi 扩展:删除分区先检测是否已挂载 #!/bin/bash
#
for I in `mount | grep "/dev/sdb" | awk '{print $1}'`;do
fuser -km $I #fuser -km /dev/sda1 #杀死所有使用sda1的进程
umount $I
echo "$I umonut OK."
done
脚本分析:
1.删除分区: dd if=/dev/zero of=/dev/hda bs=512 count=1
dd 用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换
if= :输入文件名
of=: 输出文件名
bs : 指定读入/输出的块大小,字节
count:#块个数
用空字节覆盖MAR引导,既删除分区整个硬盘分区
将U盘当前状态保存下来成为一个文件。
dd if=/dev/sdb of=/backup/ISO/Upan/save.iso
cat /dev/cdrom > xx.iso
mkisofs -r -o xx.iso /dev/cdrom
2.取出硬盘列表:
fdisk -l 2> /dev/null |grep "Disk /dev/[sh]d[a-z]" | awk -F: '{print $1}'
3.脚本创建分区
echo 'n
n
p
1
+20M