美文网首页
awk练习题

awk练习题

作者: 芷_念 | 来源:发表于2017-07-17 21:36 被阅读0次

    1 、统计/etc/fstab 文件中每个文件系统类型出现的次数

    [root@centos7 ~]# awk '/^UUID*/{filetype[$3]++}END{for
    (i in filetype){print i,filetype[i]}}' /etc/fstab
    
     swap 1
     xfs 3 
    

    2 、统计/etc/fstab 文件中每个单词出现的次数
     awk '{for(i=0;i<=NF;i++){count[$i]++}}END{for(i in count)
      {print i,count[i]}}' /etc/fstab
    
       man 1
       May 1
       and/or 1 
       maintained 1 
       xfs 3 
    

    3 、提取出字符串Yd$C@M05MB%9&Bdh7dq+YVixp3vpw中的所有数字
    echo "Yd$C@M05MB%9&Bdh7dq+YVixp3vpw"|awk -F "[^[:digit:]]"
     '{for(k=1;k<=NF;k++){count[$k]}}END{for(i in count){printf
     "%s",i}printf   "\n"}'
    
      79053
    

    4 、解决DOS 攻击生产案例:根据web 日志或者或者网络连接数,监控当某个IP 并发连接数或者短时内PV 达到100 ,即调用防火墙命令封掉对应的IP ,监控频率每隔5 分钟。防火墙命令为:iptables -A INPUT -s IP -j REJECT
    [root@shell scripts]# vidos.sh
    #!/bin/bash
    log=/tmp/tmp.log
    [ -f $log ] || touch $log
    function add_iptables()
    {while read line
    do
        ip=`echo $line|awk '{print $2}'`
        count=`echo $line|awk '{print $1}'`
      if [ $count -gt 100 ] && [ `iptables -L -n|grep "$ip"|
          wc -l`-lt 100 ]
      then
         iptables -I INPUT -s $ip -j DROP
          echo "$line is dropped">>/tmp/droplist.log
      fi
    done <$log
    }
    function main()
    {while true
      do
        netstat -an|grep EST|awk -F '[ :]+' '{print $6}'|sort|
        uniq -c >$log
        add_iptable
        ssleep 180
        done
    }
    main
    

    5:统计netstat -tan 中各状态的次数
    每出现一被/^tcp/模式匹配到的行,数组S[$NF]就加1,NF为当前匹配到的行的最后一个字段,此处用其值做为数组S的元素索引

    netstat -tan|awk '/^tcp/{state[$NF]++}END{for(i in state)
    {print i,state[i]}}'
    
       LISTEN 12 
       ESTABLISHED 1 
    

    6:统计出/etc/passwd文件中shell的种类和个数
    awk -F: '{shell[$NF]++}END{for (i in shell){print i ,
      shell[i]}}' /etc/passwd
    
    
     /bin/sync 1 
     /bin/bash 2 
     /sbin/nologin 39 
     /sbin/halt 1
     /sbin/shutdown 1 
    

    重点解析一下这条命令: 首先,shell[$NF]++这个语句。其中的$NF所代表的是一个字符串,即shell的类型。也就是说在这个数组中的元素名称是shell的名称。而后面的++是对这个数组进行赋值。因在/etc/passwd 这个文件中的shell类型四种。也就是说这个数组就有四个元素,并且它的值是不断被更新的。其次,语句for( i in shell)是设定了i是数组shell中的坐标变量,即是i是元素的名称,shell[i]是数组的值。

    7:计算/etc/passwd中所有用户的UID平均数,以及GID平均数.
    输出格式:
    UID and GID AVG
    UID-AVG : 1750.72
    GID_AVG : 1754

    [root@centos7 ~]# awk -F: '{U+=$3;G+=$4}END{print "U_avg:"
      U/NR"\nG_avg:"G/NR}' /etc/passwd
    
     U_avg:1779.89
     G_avg:1760.84 
    

    8:使用:符号做分隔符,将字段逆序输出/etc/passwd文件的每行
     awk -F: '{for(i=NF;i>1;i--)printf "%s:",$i;print $i}' 
       /etc/passwd
    
       /bin/bash:/root:root:0:0:x:root
       /sbin/nologin:/bin:bin:1:1:x:bin 
       /sbin/nologin:/sbin:daemon:2:2:x:daemon
       /sbin/nologin:/var/adm:adm:4:3:x:adm
       /sbin/nologin:/var/spool/lpd:lp:7:4:x:lp 
    

    9:统计ps中VSZ,RSS各自总和
     ps aux|awk 'BEGIN{print "ps MEM statistic"}{V+=$5;R+=$6}
      END{print "VSZ_SUM: "V/1024"M\n""RSS_SUM:"R/1024"M"}'
    
     ps MEM statistic
     VSZ_SUM: 31116.6M
     RSS_SUM:678.012M 
    

    10:根据uid值给用户分等级 Admin system users输出格式:

    LEVEL NAME
    Admin root
    sysuser bin
    users seke

    [root@centos7 ~]# awk -F: 'BEGIN{print "LEVEL\t\tNAME"}
    {if($3==0){a++;print"admin\t\t"$1"\n"}
     else if($3<500){s++;print "sysuser\t\t"$1"\n"}
     else{u++;print "user\t\t"$1"\n"}} END{print "admin:"a,
     "sysuser:"s,"user:"u}' /etc/passwd
    
        LEVEL   NAME
        admin       root
        sysuser    bin
        sysuser   daemon
        sysuser   admsys
    

    `

    相关文章

      网友评论

          本文标题:awk练习题

          本文链接:https://www.haomeiwen.com/subject/mofqkxtx.html