过滤nginx日志并添加防火墙拒绝访问 centos7

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了过滤nginx日志并添加防火墙拒绝访问 centos7相关的知识,希望对你有一定的参考价值。

#/bin/bash
#日志文件
logfile=‘/var/log/nginx/access.log‘

hours=1

#开始时间
start_time=date -d "-$hours hour" +"%H:%M:%S"
#echo $start_time

#结束时间
stop_time=date +"%H:%M:%S"

#echo $stop_time
#过滤出单位之间内的日志并统计最高ip数
array=($(tac $logfile | awk -v st="$start_time" -v et="$stop_time" ‘{t=substr($4,RSTART+14,21);if(t>=st && t<=et) {print $0}}‘
| awk ‘{print $1}‘ | sort | uniq -c | sort -nr |awk ‘{if($1 > 5000){print $0}}‘|awk ‘{print $2}‘))

wait

for each in ${array[@]}
do

echo $each

firewall-cmd --permanent --add-rich-rule="rule family=‘ipv4‘ source address=‘$each‘ reject"

done

firewall-cmd --reload

以上是关于过滤nginx日志并添加防火墙拒绝访问 centos7的主要内容,如果未能解决你的问题,请参考以下文章

centos7搭建nginx日志

ELK 6安装配置 nginx日志收集 kabana汉化

centos下docker方式安装onlyoffice

nginx访问控制

一次特别奇怪的Web问题,内网访问服务器正常,外网不能访问服务器

nginxaccess设置允许多个网段的机器访问