IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> 自动化分析Nginx日志实现恶意访问异常报警 -> 正文阅读

[系统运维]自动化分析Nginx日志实现恶意访问异常报警

为了防止一些恶意访问的行为,例如不断的请求刷流量,通过实时过滤Nginx访问日志,将单位时间内访问次数达到指定阀值的来源ip及时的通知系统管理员,这里通过邮件的方式通知。
监控脚本:
`vim /opt/nginx/sbin/nginx_log_monitor.sh
#!/bin/bash
#日志文件
logfile=/opt/nginx/logs/

#开始时间
start_time=date -d"$last_minutes minutes ago" +"%H:%M:%S"

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

#过滤出单位之间内的日志并统计最高ip数
tac l o g f i l e / a c c e s s . l o g ∣ a w k ? v s t = " logfile/access.log | awk -v st=" logfile/access.logawk?vst="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 > $logfile/log_ip_top10
ip_top=cat $logfile/log_ip_top10 | head -1 | awk '{print $1}'

单位时间[1分钟]内单ip访问次数超过200次,则触发邮件报警

if [[ $ip_top -gt 200 ]];then
/usr/bin/python /opt/tools/send_mail.py &
fi`

chmod +x /opt/nginx/sbin/nginx_log_monitor.sh

定时任务
如上脚本监控一分钟内的日志,因此每分钟执行一次:

# crontab -e
*/1 * * * * /bin/bash /opt/nginx/sbin/nginx_log_monitor.sh

邮件告警
这里通过python实现发送邮件

# vim /opt/tools/send_mail.py

-- coding: utf-8 --

from email import encoders
from email.header import Header
from email.mime.text import MIMEText
from email.utils import parseaddr, formataddr
from email.mime.multipart import MIMEMultipart
from email.mime.base import MIMEBase
from datetime import datetime
import os
import smtplib
def _format_addr(s):
name, addr = parseaddr(s)
return formataddr((Header(name, ‘utf-8’).encode(), addr))

邮箱定义

smtp_server = ‘xxxxx’
smtp_port = 465
from_addr = ‘xxxx@163.com’
password = os.environ.get(‘MAIL_PASSWD’)
to_addr = [‘xxxx@163.com’]

邮件对象

msg = MIMEMultipart()
msg[‘From’] = _format_addr(‘发件人 <%s>’ % from_addr)
msg[‘To’] = _format_addr(‘收件人 <%s>’ % to_addr)
msg[‘Subject’] = Header(‘Warning:单ip请求次数异常’, ‘utf-8’).encode()

获取系统中要发送的文本内容

with open(‘/opt/nginx/logs/log_ip_top10’, ‘r’) as f:
line = f.readline().strip()
line = line.split(" ")
print(line)

邮件正文是MIMEText:

html = ‘

一分钟内单ip请求次数超过阀值

’ +

ip:%s 请求次数/min:%s

’ % (line[1],line[0]) +
‘’
msg.attach(MIMEText(html, ‘html’, ‘utf-8’))
server = smtplib.SMTP_SSL(smtp_server, smtp_port)
server.login(from_addr, password)
server.sendmail(from_addr, to_addr, msg.as_string())
server.quit()

示例

写个脚本不停curl请求资源触发报警:

# vim curl.sh
#!/bin/bash
#example:curl.sh http://xxxxxx 100
usage()
{
 echo "usage: `basename $0` url count"
}
if [ $# -ne 2 ]; then
 usage
 exit 1
fi
for i in `seq 1 $2`;do
 http_code=`curl -o /dev/null -s -w %{http_code} $1`
 echo $1 $http_code
done

bash curl.sh http://xxxxxx/ 5

http://xxxxx/ 200
http://xxxxxx/ 200
http://xxxx/ 200
http://xxxxx/ 200
http://xxxxx/ 200

调低阀值触发告警:
一分钟内单ip请求次数超过阀值
ip:115.231.182.82 请求次数/min:27

完善

这里仅实现了邮件告警功能,实际上还可以实现自动屏蔽恶意访问的ip。可以通过Nginx deny来实现,也可以iptables -I INPUT -s x.x.x.x -j DROP通过iptables屏蔽。

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2022-07-21 21:52:42  更:2022-07-21 21:54:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/19 0:28:05-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码