热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

28:awk高级应用、综合案例、总结和答疑

TopNSDSHELLDAY06案例1:awk流程控制案例2:awk扩展应用案例3:编写监控脚本案例4:编写安全检测脚本1案

Top

NSD SHELL DAY06

  1. 案例1:awk流程控制
  2. 案例2:awk扩展应用
  3. 案例3:编写监控脚本
  4. 案例4:编写安全检测脚本

1 案例1:awk流程控制

1.1 问题

本案例要求了解awk的流程控制操作,可自行设置awk语句来有验证以下操作:

  • if分支结构(单分支、双分支、多分支)
  • 练习awk数组的使用

1.2 步骤

实现此案例需要按照如下步骤进行。

步骤一:awk过滤中的if分支结构

1)单分支

统计/etc/passwd文件中UID小于或等于1000的用户个数:

[root&#64;svr5 ~]# awk -F: &#39;{if($3<&#61;1000){i&#43;&#43;}}END{print i}&#39; /etc/passwd
39

统计/etc/passwd文件中UID大于1000的用户个数&#xff1a;

[root&#64;svr5 ~]# awk -F: &#39;{if($3>1000){i&#43;&#43;}}END{print i}&#39; /etc/passwd
8

统计/etc/passwd文件中登录Shell是“/bin/bash”的用户个数&#xff1a;

[root&#64;svr5 ~]# awk -F: &#39;{if($7~/bash$/){i&#43;&#43;}}END{print i}&#39; /etc/passwd
29

2&#xff09;双分支

分别统计/etc/passwd文件中UID小于或等于1000、UID大于1000的用户个数&#xff1a;

[root&#64;svr5 ~]# awk -F: &#39;{if($3<&#61;1000){i&#43;&#43;}else{j&#43;&#43;}}END{print i,j}&#39; /etc/passwd
39 8

分别统计/etc/passwd文件中登录Shell是“/bin/bash”、 登录Shell不是“/bin/bash”的用户个数&#xff1a;

[root&#64;svr5 ~]# awk -F: &#39;{if($7~/bash$/){i&#43;&#43;}else{j&#43;&#43;}} END{print i,j}&#39; /etc/passwd
29 38

步骤二&#xff1a;awk数组

1&#xff09;数组的语法格式

数组是一个可以存储多个值的变量&#xff0c;具体使用的格式如下&#xff1a;

定义数组的格式&#xff1a;数组名[下标]&#61;元素值

调用数组的格式&#xff1a;数组名[下标]

遍历数组的用法&#xff1a;for(变量 in 数组名){print 数组名[变量]}。

[root&#64;svr5 ~]# awk &#39;BEGIN{a[0]&#61;11;a[1]&#61;88;print a[1],a[0]}&#39;
88 11
[root&#64;svr5 ~]# awk &#39;BEGIN{a&#43;&#43;;print a}&#39;
1
[root&#64;svr5 ~]# awk &#39;BEGIN{a0&#43;&#43;;print a0}&#39;
1
[root&#64;svr5 ~]# awk &#39;BEGIN{a[0]&#43;&#43;;print a[0]}&#39;
1
[root&#64;svr5 ~]# awk &#39;BEGIN{a[0]&#61;0;a[1]&#61;11;a[2]&#61;22; for(i in a){print i,a[i]}}&#39;
0 0
1 11
2 22

注意&#xff0c;awk数组的下标除了可以使用数字&#xff0c;也可以使用字符串&#xff0c;字符串需要使用双引号&#xff1a;

[root&#64;svr5 ~]# awk &#39;BEGIN{a["hehe"]&#61;11;print a["hehe"]}&#39;
11

2 案例2&#xff1a;awk扩展应用

2.1 问题

本案例要求使用awk工具完成下列两个任务&#xff1a;

  • 分析Web日志的访问量排名&#xff0c;要求获得客户机的地址、访问次数&#xff0c;并且按照访问次数排名

2.2 方案

1&#xff09;awk统计Web访问排名

在分析Web日志文件时&#xff0c;每条访问记录的第一列就是客户机的IP地址&#xff0c;其中会有很多重复的IP地址。因此只用awk提取出这一列是不够的&#xff0c;还需要统计重复记录的数量并且进行排序。

通过awk提取信息时&#xff0c;利用IP地址作为数组下标&#xff0c;每遇到一个重复值就将此数组元素递增1&#xff0c;最终就获得了这个IP地址出现的次数。

针对文本排序输出可以采用sort命令&#xff0c;相关的常见选项为-r、-n、-k。其中-n表示按数字顺序升序排列&#xff0c;而-r表示反序&#xff0c;-k可以指定按第几个字段来排序。

2.3 步骤

实现此案例需要按照如下步骤进行。

步骤一&#xff1a;统计Web访问量排名

分步测试、验证效果如下所述。

1&#xff09;提取IP地址及访问量

[root&#64;svr5 ~]# awk &#39;{ip[$1]&#43;&#43;} \
> END{for(i in ip) {print ip[i],i }}&#39; /var/log/httpd/access_log
4 127.0.0.1
17 192.168.4.5
13 192.168.4.110
.. ..

2&#xff09;对第1&#xff09;步的结果根据访问量排名

[root&#64;svr5 ~]# awk &#39;{ip[$1]&#43;&#43;} END{for(i in ip) {print i,ip[i]}}&#39; /var/log/httpd/access_log | sort -nr
17 192.168.4.5
13 192.168.4.110
4 127.0.0.1
.. ..

3 案例3&#xff1a;编写监控脚本


3.1 问题

本案例要求编写脚本&#xff0c;实现计算机各个性能数据监控的功能&#xff0c;具体监控项目要求如下&#xff1a;


  • CPU负载
  • 网卡流量
  • 内存剩余容量
  • 磁盘剩余容量
  • 计算机账户数量
  • 当前登录账户数量
  • 计算机当前开启的进程数量
  • 本机已安装的软件包数量

3.2 步骤

实现此案例需要按照如下步骤进行。

步骤一&#xff1a;准备工作

1&#xff09;查看性能数据的命令

[root&#64;svr5 ~]# uptime //查看CPU负载
[root&#64;svr5 ~]# ifconfig eth0 //查看网卡流量
[root&#64;svr5 ~]# free //查看内存信息
[root&#64;svr5 ~]# df //查看磁盘空间
[root&#64;svr5 ~]# wc -l /etc/passwd //查看计算机账户数量
[root&#64;svr5 ~]# who |wc -l //查看登录账户数量
[root&#64;svr5 ~]# rpm -qa |wc -l //查看已安装软件包数量

步骤二&#xff1a;编写参考脚本

1&#xff09;脚本内容如下&#xff1a;

[root&#64;svr5 ~]# vim test.sh
#!/bin/bash
ip&#61;&#96;ifconfig eth0 | awk &#39;/inet /{print $2}&#39;&#96;
echo "本地IP地址是:"$ip
cpu&#61;&#96;uptime | awk &#39;{print $NF}&#39;&#96;
#awk中NF为当前行的列数&#xff0c;$NF是最后一列
echo "本机CPU最近15分钟的负载是:"$cpu
net_in&#61;&#96;ifconfig eth0 | awk &#39;/RX p/{print $5}&#39;&#96;
echo "入站网卡流量为:"$net_in
net_out&#61;&#96;ifconfig eth0 | awk &#39;/TX p/{print $5}&#39;&#96;
echo "出站网卡流量为:"$net_out
mem&#61;&#96;free | awk &#39;/Mem/{print $4}&#39;&#96;
echo "内存剩余容量为:"$mem
disk&#61;&#96;df | awk &#39;/\/$/{print $4}&#39;&#96;
echo "根分区剩余容量为:"$disk
user&#61;&#96;cat /etc/passwd |wc -l&#96;
echo "本地账户数量为:"$user
login&#61;&#96;who | wc -l&#96;
echo "当前登陆计算机的账户数量为:"$login
process&#61;&#96;ps aux | wc -l&#96;
echo "当前计算机启动的进程数量为:"$process
soft&#61;&#96;rpm -qa | wc -l&#96;
echo "当前计算机已安装的软件数量为:"$soft

4 案例4&#xff1a;编写安全检测脚本


4.1 问题

本案例要求编写脚本&#xff0c;防止远程ssh暴力破解密码&#xff0c;具体监控项目要求如下&#xff1a;


  • 检测ssh登录日志&#xff0c;如果远程登陆账号名错误3次&#xff0c;则屏蔽远程主机的IP
  • 检测ssh登录日志&#xff0c;如果远程登陆密码错误3次&#xff0c;则屏蔽远程主机的IP

4.2 步骤

实现此案例需要按照如下步骤进行。

步骤一&#xff1a;准备工作

1&#xff09;过滤帐户名失败的命令(登陆日志文件为/var/log/secure)

[root&#64;svr5 ~]# awk &#39;/Invalid user/{print $10}&#39; /var/log/secure

2&#xff09;过滤密码失败的命令

[root&#64;svr5 ~]# awk &#39;/Failed password/{print $11}&#39; /var/log/secure

步骤二&#xff1a;编写参考脚本

1&#xff09;脚本内容如下&#xff1a;

[root&#64;svr5 ~]# vim test.sh
#!/bin/bash
awk &#39;/Failed password/{print $11}&#39; /var/log/secure | awk &#39;{ip[$1]&#43;&#43;}END{for(i in ip){print ip[i],i}}&#39; | awk &#39;$1>3{print $2}&#39;

awk ‘/Invalid user/{print $10}’ /var/log/secure | awk ‘{ip[$1]&#43;&#43;}END{for(i in ip){print ip[i],i}}’ | awk ‘$1>3{print $2}’


推荐阅读
  • 采用IKE方式建立IPsec安全隧道
    一、【组网和实验环境】按如上的接口ip先作配置,再作ipsec的相关配置,配置文本见文章最后本文实验采用的交换机是H3C模拟器,下载地址如 ... [详细]
  • 如何使用Ping命令来测试网络连接?当网卡安装和有关参数配置完成后,可以使用ping命令来测试一下网络是否连接成功。以winXP为例1、打开XP下DOS窗口具体操作是点击“开始”菜 ... [详细]
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • 本文详细介绍了一种通过MySQL弱口令漏洞在Windows操作系统上获取SYSTEM权限的方法。该方法涉及使用自定义UDF DLL文件来执行任意命令,从而实现对远程服务器的完全控制。 ... [详细]
  • Hadoop发行版本选择指南:技术解析与应用实践
    本文详细介绍了Hadoop的不同发行版本及其特点,帮助读者根据实际需求选择最合适的Hadoop版本。内容涵盖Apache Hadoop、Cloudera CDH等主流版本的特性及应用场景。 ... [详细]
  • 福克斯新闻数据库配置失误导致1300万条敏感记录泄露
    由于数据库配置错误,福克斯新闻暴露了一个58GB的未受保护数据库,其中包含约1300万条网络内容管理记录。任何互联网用户都可以访问这些数据,引发了严重的安全风险。 ... [详细]
  • Linux系统中Java程序Too Many Open Files问题的深入解析与解决方案
    本文详细分析了在Linux环境下运行的Java应用程序中可能出现的“Too many open files”异常现象,探讨其成因及解决方法。该问题通常出现在高并发文件访问或大量网络连接场景下,对系统性能和稳定性有较大影响。 ... [详细]
  • JavaScript 中创建对象的多种方法
    本文详细介绍了 JavaScript 中创建对象的几种常见方式,包括对象字面量、构造函数和 Object.create 方法,并提供了示例代码和属性描述符的解释。 ... [详细]
  • Nginx 反向代理与负载均衡实验
    本实验旨在通过配置 Nginx 实现反向代理和负载均衡,确保从北京本地代理服务器访问上海的 Web 服务器时,能够依次显示红、黄、绿三种颜色页面以验证负载均衡效果。 ... [详细]
  • 本文介绍了在Java环境中使用PDFBox和XPDF工具从PDF文件中提取文本内容的方法。重点讨论了处理中文字符集及解决相关错误的技术细节,特别是针对某些特定格式的PDF文件(如网上填写的报名表和下载的论文)遇到的问题及解决方案。 ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • 本文详细介绍了如何在PHP中进行数组删除、清空等操作,并提供了在Visual Studio Code中创建PHP文件的步骤。 ... [详细]
  • 使用PHP实现网站访客计数器的完整指南
    本文详细介绍了如何利用PHP构建一个简易的网站访客统计系统。通过具体的代码示例和详细的解释,帮助开发者理解和实现这一功能,适用于初学者和有一定经验的开发人员。 ... [详细]
  • 雨林木风 GHOST XP SP3 经典珍藏版 V2017.11
    雨林木风 GHOST XP SP3 经典珍藏版 V2017.11 ... [详细]
  • 优化网页加载速度:JavaScript 实现图片延迟加载
    本文介绍如何使用 JavaScript 实现图片延迟加载,从而显著提升网页的加载速度和用户体验。 ... [详细]
author-avatar
手机用户2502853457
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有