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]