news 2026/2/28 18:14:27

AWK 文本练习题

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
AWK 文本练习题

1检测两台服务器指定目录下的文件一致性

2.定时清空文件内容,定时记录文件大小

3.检测网卡流量,并按规定格式记录在日志中

4.计算文档每行出现的数字个数,并计算整个文档的数字总数

5.创建10个用户,并分别设置密码,密码要求10位且包含大小写字母以及数字,
最后需要把每个用户的密码存在指定文件中

6.查看CPU资源占用率的脚本文件

7.生成磁盘使用情况的日志文件

8.扫描主机端口状态

9.监控 httpd 的进程数,根据监控情况做相应处理

代码:

#!/bin/bash
#######################################################################################
#需求:
#1.每隔10s监控httpd的进程数,若进程数大于等于500,则自动重启Apache服务,并检测服务是否重启成功
#2.若未成功则需要再次启动,若重启5次依旧没有成功,则向管理员发送告警邮件,并退出检测
#3.如果启动成功,则等待1分钟后再次检测httpd进程数,若进程数正常,则恢复正常检测(10s一次),否则放弃重启并向管理员发送告警邮件,并退出检测
#######################################################################################
#计数器函数
check_service()
{
j=0
for i in `seq 1 5`
do
#重启Apache的命令
/usr/local/apache2/bin/apachectl restart 2> /var/log/httpderr.log
#判断服务是否重启成功
if [ $? -eq 0 ]
then
break
else
j=$[$j+1]
fi
#判断服务是否已尝试重启5次
if [ $j -eq 5 ]
then
mail.py
exit
fi
done
}
while :
do
n=`pgrep -l httpd|wc -l`
#判断httpd服务进程数是否超过500
if [ $n -gt 500 ]
then
/usr/local/apache2/bin/apachectl restart
if [ $? -ne 0 ]
then
check_service
else
sleep 60
n2=`pgrep -l httpd|wc -l`
#判断重启后是否依旧超过500
if [ $n2 -gt 500 ]
then
mail.py
exit
fi
fi
fi
#每隔10s检测一次
sleep 10
done

图例:

10.根据web访问日志,封禁请求量异常的IP,如IP在半小时后恢复正常,则解除封禁

代码如下:

logfile=/data/log/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 i in `awk '$1>100 {print $2}' $ips`
do
$ipt -I INPUT -p tcp --dport 80 -s $i -j REJECT
echo "`date +%F-%T` $i" >> /tmp/badip.log
done
}
unblock()
{
for a in `$ipt -nvL INPUT --line-numbers |grep '0.0.0.0/0'|awk '$2<10 {print $1}'|sort -nr`
do
$ipt -D INPUT $a
done
$ipt -Z
}

if [ $d2 -eq "00" ] || [ $d2 -eq "30" ]
then

unblock
block
else
block
fi

实操图:

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/14 11:09:34

揭秘NVIDIA官方推理黑科技:TensorRT镜像全解析

揭秘NVIDIA官方推理黑科技&#xff1a;TensorRT镜像全解析 在AI模型越来越“重”的今天&#xff0c;一个训练好的神经网络从实验室走向生产环境&#xff0c;往往要经历一场残酷的现实考验。你可能在论文里看到某个模型准确率高达98%&#xff0c;但在真实服务中却因为一次推理耗…

作者头像 李华
网站建设 2026/2/26 11:17:01

举办线下Meetup:聚集本地AI开发者交流实践经验

聚焦本地AI开发者&#xff1a;深入实践TensorRT推理优化技术 在今天&#xff0c;一个训练精度高达95%的图像分类模型&#xff0c;部署上线后却因为每帧处理耗时超过40毫秒而无法满足实时视频分析的需求——这样的场景&#xff0c;在AI工程化落地过程中并不少见。实验室里的SOTA…

作者头像 李华
网站建设 2026/2/25 21:49:27

许可证管理模式:避免因开源协议引发法律纠纷

许可证管理模式&#xff1a;避免因开源协议引发法律纠纷 在人工智能技术加速落地的今天&#xff0c;越来越多的企业将深度学习模型部署到生产环境中&#xff0c;追求极致的推理性能。NVIDIA TensorRT 作为 GPU 加速推理的事实标准之一&#xff0c;凭借其强大的优化能力&#xf…

作者头像 李华
网站建设 2026/2/26 20:04:35

推动标准制定:参与AI推理优化相关行业规范起草

推动标准制定&#xff1a;参与AI推理优化相关行业规范起草 在当今AI模型加速落地的浪潮中&#xff0c;一个现实问题日益凸显&#xff1a;训练阶段表现优异的深度学习模型&#xff0c;一旦进入生产环境&#xff0c;往往“水土不服”——推理延迟高、吞吐量低、资源消耗大。这种…

作者头像 李华
网站建设 2026/2/24 19:42:20

【GitHub项目推荐--Self-hosted AI Starter Kit:本地AI工作流快速启动模板】

简介 ​Self-hosted AI Starter Kit是由n8n团队开发的开源Docker Compose模板&#xff0c;旨在帮助开发者快速搭建完整的本地AI开发环境。该项目整合了自托管的n8n低代码平台、Ollama本地大语言模型运行环境、Qdrant向量数据库和PostgreSQL数据库等核心组件&#xff0c;让用户…

作者头像 李华