一,先判断一下你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