Linux shell脚本练习(五)

防止ddos攻击,当某个ip访问过于频繁不合理时,对其进行屏蔽

bash 复制代码
#!/bin/bash
DATE=$(date +%d/%b/%Y:%H:%M)
LOG_FILE=/usr/local/nginx/logs/demo2.access.log
ABNORMAL_IP=$(tail -n5000 $LOG_FILE |grep $DATE |awk '{a[$1]++}END{for(i in a)if(a[i]>10)print i}')
for IP in $ABNORMAL_IP; do
    if [ $(iptables -vnL |grep -c "$IP") -eq 0 ]; then
        iptables -I INPUT -s $IP -j DROP
        echo "$(date +'%F_%T') $IP" >> /tmp/drop_ip.log
    fi
done

root@linux-lyz test1\]# chmod +x ddos.sh \[root@linux-lyz test1\]# ./ddos.sh \[root@linux-lyz test1\]#

nginx 日志按日期切割

bash 复制代码
#!/bin/bash
LOG_DIR=/usr/local/nginx/logs
YESTERDAY_TIME=$(date -d "yesterday" +%F)
LOG_MONTH_DIR=$LOG_DIR/$(date +"%Y-%m")
LOG_FILE_LIST="default.access.log"

for LOG_FILE in $LOG_FILE_LIST; do
    [ ! -d $LOG_MONTH_DIR ] && mkdir -p $LOG_MONTH_DIR
    mv $LOG_DIR/$LOG_FILE $LOG_MONTH_DIR/${LOG_FILE}_${YESTERDAY_TIME}
done

kill -USR1 $(cat /var/run/nginx.pid)

root@linux-lyz test1\]# ./split_nginx_log.sh \[root@linux-lyz test1\]# mkdir -p /usr/local/nginx/logs/2024-12 \[root@linux-lyz test1\]# mv /usr/local/nginx/logs/default.access.log /usr/local/nginx/logs/2024-12/default.access.log_2024-12-16 \[root@linux-lyz test1\]# kill -USR1 25423 \[root@linux-lyz test1\]#

相关推荐
小锋学长生活大爆炸2 小时前
【教程】CentOS在不知道root密码的情况下进入shell和重置密码
linux·运维·centos
代码游侠2 小时前
学习笔记——GDB调试工具
linux·开发语言·笔记·学习
通义灵码2 小时前
Qoder Linux 版公测上线
linux·运维·服务器
福尔摩斯张2 小时前
从Select到Epoll:深度解析Linux I/O多路复用演进之路(超详细)
linux·运维·服务器·c语言·网络
weixin_387002153 小时前
二次开发的openssl在windows平台的编译
linux·windows·安全·ssl
视觉装置在笑7133 小时前
grep 命令基础用法
linux·运维
HalvmånEver3 小时前
Linux:进程等待(进程控制三)
linux·运维·服务器
干啥都是小小白3 小时前
Linux 驱动
linux·运维·服务器
向山行_wolf3 小时前
ubuntu20.04安装向日葵
linux·运维·服务器
飘忽不定的bug3 小时前
记录:ubuntu20.04隐藏鼠标指针
linux·ubuntu