cheng029 发表于 2018-8-24 08:15:30

shell 脚 本 练 习 题(四)

  一,先判断一下你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 77105 141 .......
#! /bin/bash  
x=21
  
m=10
  
echo $m
  
for i in `seq 0 14`; do
  
    j=$
  
    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
页: [1]
查看完整版本: shell 脚 本 练 习 题(四)