一,先判断一下你linux的版本和bash版本,然后看看是否需要升级,若是升级,则使用yum直接升级,否则输出一条日志,告之不需要升级。

#!/bin/bash
os_ver=cat /etc/redhat-release|awk -F "."  '{print $1}'|awk '{print $3}' #获取linux版本号,并进行处理
bash_ver= rpm -qa bash|sed 's/.i686//g'|sed 's/.x86_64//g' #获取bash版本号,并进行处理
case $os_ver in #判断linux版本为5还是6,并跳转到相应的command进行bash版本的判断
6)
    if [ "$bash_ver" != "bash-4.1.2-15.el6_5.1" ]#判断的bash的版本是否为bash-4.1.2-15.el6_5.1,是则升级,不是则提示不需要升级
    then 
        yum update -y bash
    else
        echo "Bash not need to update!"
      fi  
    ;;
5)
    if [ "$bash_ver" != "bash-3.2-33.el5.1" ]
#判断的bash的版本是否为bash-3.2-33.el5.1,是则升级,不是则提示不需要升级
    then
        yum update -y bash
    else
        echo "Bash not need to update!"
    fi
     ;;
esac

二,假如我们需要每小时都去执行你写的脚本。在脚本中实现这样的功能,当时间是0点和12点时,需要将目录/data/log/下的文件全部清空,注意只能清空文件内容而不能删除文件。而其他时间只需要统计一下每个文件的大小,一个文件一行,输出到一个按日期和时间为名字的日志里。 考虑/data/log/目录下的二级、三级。。。子目录里面的文件。

#!/bin/bash
path="/data/log"
time=`date +%F-%T`
time1=`date +%H`
while :
do
if [ $time1 -eq 0 -o $time1 -eq 12 ]
then
find $path -type f  -exec cp  /dev/null {} \;
else
find $path -type f -exec ls -l {} \; | awk '{print $5,$NF}'>${time}.txt
fi
sleep 3600
done

如果不加sleep 3600的话,加到 crontab里面

* */1 * * *  sh /path/clean.sh

#!/bin/bash
if [ ! -d ~/log ] #判断是否存在存储日志的路径,不存在则创建
then
        mkdir -p ~/log
fi
file=~/log/`date +%Y%m%d%H%M%S`.txt  #在~/log里创建以日期时间命名的文件用于保存文件大小信息
if [ `date +%H` -eq 0 ]||[ `date +%H` -eq 12 ]  #判断时间是否为0点或12点,由于是每隔1小时执行一次,此处不对分钟进行比较
then
       for i in `/bin/find /data/log -type f`;do #查找文件
                 echo "" >$i #清空内容
       done
else
       for i in `/bin/find /data/log -type f`;do #查找文件
               /usr/bin/du -sh $i >> $file #将文件大小信息存入以日期时间命名的文件,>>会自动换行
        done
fi

三,写一个shell脚本来看看你最喜欢敲的命令是哪个?然后列出你最喜欢敲的命令top10。

cat ~/.bash_history | awk '{print $1}' | sort |uniq -c | sort -rn |head -n 10 |sed "$i"'p' -n | awk '{print $2}'

cat  .bash_history |sort -n |uniq -c |sort -rn |head -10

四,写个shell,看看你的Linux系统中是否有自定义用户(普通用户),若是有,一共有几个?

#!/bin/bash
n=`awk -F ':' '$3>=500' /etc/passwd|wc -l`
if [ $n -gt 0 ]
then
    echo "There are $n common users."
else
    echo "No common users."
fi

五,请详细查看如下几个数字的规律,并使用shell脚本输出后面的十个数字。10 31 53 77  105 141 .......

#! /bin/bash
x=21
m=10
echo $m
for i in `seq 0 14`; do
    j=$[2**$i]
    m=$[$m+$x]
    echo $m
    x=$[$x+$j]
done

六,需求: 根据web服务器上的访问日志,把一些请求量非常高的ip给拒绝掉! 

分析: 我们要做的,不仅是要找到哪些ip请求量不合法,并且还要每隔一段时间把之前封掉的ip(若不再继续请求了)给解封。 所以该脚本的关键点在于定一个合适的时间段和阀值。 比如, 我们可以每一分钟去查看一下日志,把上一分钟的日志给过滤出来分析,并且只要请求的ip数量超过50次那么就直接封掉。 而解封的时间又规定为每半小时分析一次,把几乎没有请求量的ip给解封!

#! /bin/bashlogfile=/home/logs/client/access.log
d1=`date -d "-1 minute" +%H:%M`
d2=`date +%M`
ipt=/sbin/iptables
ips=/tmp/ips.txt
block(){
    grep "$d1:" $logfile|awk '{print $1}' |sort -n |uniq -c |sort -n >$ips
    for ip in `awk '$1>50 {print $2}' $ips`; do
        $ipt -I INPUT -p tcp --dport 80 -s $ip -j REJECT
        echo "`date +%F-%T` $ip" >> /tmp/badip.txt
    done
}
unblock(){
    for i in `$ipt -nvL --line-numbers |grep '0.0.0.0/0'|awk '$2<15 {print $1}'|sort -nr`; do
        $ipt -D INPUT $i
    done
    $ipt -Z
}
if [ $d2 == "00" ] || [ $d2 == "30" ]; then
    unblock
    block
else
    block
fi