一、定时倒计时
定时倒计时,我们有两种思路。分别是逻辑的方式和运算的方式,两种思路编写的脚本都可以满足我们的定时倒计时需求。
这里我们定时为70秒,即1分10秒。来为大家演示
1.逻辑
使用逻辑的方式,其实就是进行输入分(MIN)和秒(SEC)参照于0秒,来对比。当输入的MIN、SEC都等于0时。计时结束;当输入的MIN大于等于0,SEC为0时,使用for语句进行循环,让这部分语句每秒循环一次,SEC每次减一这个时候由于我们设定的MIN为1分钟,所以SEC=60(其他的MIN设定时,SEC= [ [ [MIN*60]),即可实现倒计时;排除以上两种情况后,其余的情况正常输出我们想要的倒计时格式就可以了。
MIN=1
SEC=10
for ((;SEC>=0;SEC--))
do
if [ "$SEC" = "0" -a "$MIN" = "0" ]
then
echo "time is end!!"
exit
elif [ "$SEC" -eq "0" -a "$MIN" -ge "0" ]
then
echo -ne "$MIN:$SEC"
echo -ne "\r"
sleep 1
SEC=60
((MIN--))
else
echo -ne "$MIN:$SEC"
echo -ne "\r"
sleep 1
fi
done
2.运算
使用运算时,需要引入时间总和SECS(所有秒),以SECS作为for语句执行的对象。同样时是,每秒循环一次,每次SECS减一。在输出倒计时格式上, [ [ [SECS/60]这个部分是给SECS除以60,得到剩余分钟的数量(由于shell中,在不提前设定的情况下运算取得都是整数部分)。同理, [ [ [SECS%60]给SECS除以60取余数就是剩余秒的数量。
MIN=1
SEC=10
SECS=$[$MIN*60+SEC]
for ((;SECS;SECS--))
do
echo -ne "$[$SECS/60]:$[$SECS%60]"
sleep 1
echo -ne "\r"
done
二、抽取随机数
随机数抽取,最重要的环节其实就是搞清楚如何获得随机数,$RANDOM可以帮我们获取一个随机数。
掌握了随机数的获得后,下面这段脚本简单给大家演示了一下获得随机数后的一些操作。
脚本内容是一个幸运数字选取的小游戏。
SUIJI=$[$RANDOM%10]
while true
do
read -p "Please input a number:" NUM
if [ "$NUM" -eq "$SUIJI" ]
then
echo "$NUM is lucky number"
exit
elif [ "$NUM" -lt "$SUIJI" ]
then
echo "$NUM is small"
else
echo "$NUM is large"
fi
done
三、用户表及密码表建立用户
使用用户表以及密码表建立用户的难:
1 . 检测脚本运行后是否有两个文件存在
2 . 两个文件的行数是否匹配
3 . 行数匹配的情况下,如何在建立用户、添加密码时,让两个文件的内容逐行输出。
解决了这三个难点后,余下的工作就是将这三个部对应的部分,进行合理的组合,让其成功输出我们想要的结果。
if [ "$#" -lt "2" ]
then
echo "Please input userlist and passlist following $0:"
elif [ ! -e "$1" ]
then
echo "$1 is not exist"
elif [ ! -e "$2" ]
then
echo "$2 is not exist" ##以上是检测是否有两个文件的部分。
else
ULINE=`awk 'END{print NR}' $1` ##统计文件1的行数
PLINE=`awk 'END{print NR}' $2` ##统计文件2的行数
[ "$ULINE" -ne "$PLINE" ] && {
echo "lines of $1 is different from $2"
} || {
for LINE in `seq 1 $ULINE`
do
USER=`sed -n ${LINE}p $1` ##逐行输出文件1的内容
PASS=`sed -n ${LINE}p $2` ##逐行输出文件2的内容
id $USER &> /dev/null && {
echo "$USER is exist"
userdel -r $USER
echo $USER is deleted
}||{
useradd $USER
echo $PASS | passwd --stdin $USER &>/dev/null
echo $USER is created
}
done
}
fi
四、抓取CPU和MEM的占用率
抓取cpu以及mem占用率关键点在于能否精确地截取到系统当前所有cpu、mem的使用情况,并总和输出。
echo "CPUused: `ps ax -o %cpu | awk 'BEGIN{C=0}!/0.0|CPU/{C+=$1}END{print C}'`%"
echo "MEMused: `ps ax -o %mem | awk 'BEGIN{M=0}!/0.0|MEM/{M+=$1}END{print M}'`%"
该脚本的代码段中:
awk ‘BEGIN{C=0}!/0.0|CPU/{C+=$1}END{print C}’ 意思是筛选 | 之前的输出,作为输入,筛选出CPU这一列并制定一个变量C,排除掉CPU这一列中是0.0的行,其他行累加。最后输出C的值,就是当前系统cpu占用率的总和。同理,mem也可以这样操作,获取当前系统mem的占用率。
五、数据库备份
!执行数据库备份脚本,数据库密码为:westos
!脚本执行后,会备份书局库中的所有库到/mnt/mysqldump目录中
!备份文件的名称为“库的名称.sql”当文件存在时报错并询问动作
输入S时,跳过备份
输入B时,备份“库名称.sql”文件为库名称_backup.sql
输入O时,覆盖源文件
这个脚本书写时,难度其实大家想象中那么大。检测部分类似于我们之前做过的Apache端口管理,新加的内容其实是数据库密码的部分,图片中有详细的步骤。
控制部分,主要是while与case的使用,大家可以在熟练熟练while与case,加深自己对语句的熟悉程度。
这个部分是数据库备份的检测部分,检测是否输入数据库密码、数据库是否存在、数据库是否运行、数据库密码是否正确
这个部分则对用的是采取备份时可以执行的动作
六、swap分区自动建立
swap分区的自动建立,关键点在与自动应答这个部分。
并且在磁盘分区时,完成分区会出现两种情况都需要考虑到。
分区完成后,对磁盘格式的转换正常的设置自动应答语句,就可以完成。
注意!!fdisk 磁盘!!完成后,还需要对其进行格式化,才可以。
echo “/dev/vdb$DIS swap swap defaults 0 0” >> /etc/fstab
swapon -a
这段语句的作用是让其在开机时可以自动激活