Products
GG网络技术分享 2025-03-18 16:16 10
相信很多站长遇到服务器被打,服务器负载和CPU占用都是100%,网站502卡死,这时候Nginx,MySQL和php的服务都没有停止运行,站长自己还不知道网站打不开了。
因为Nginx,MySQL和php的服务都没有停止运行,所以那些守护程序都没起作用。
通过长期观察,网站被打,通常是MySQL占用太高,只有重启MySQL才有效,虽然频繁重启MySQL有可能造成数据崩溃,也没有其他办法。只有在被打的时候开启用一下,先保证网站能正常浏览再说。
今天网站又被打了,根据自身情况,写了个shell脚本,丢到宝塔计划任务中,测试几天看看效果。
当CPU使用率达到99%重启MySQL,或MySQL停止运行时重启MySQL,宝塔面板MySQL进程守护脚本,计划任务时间不要太短,先设置5分钟观察观察。
#当CPU使用率达到99%重启MySQL,或MySQL停止运势时重启MySQL#!/bin/bash
# Get the CPU usage percentage
cpu_usage=$(top -bn1 | grep "Cpu(s)" | awk '{print $2 + $4}')
# Define the MySQL process name
mysql_process="mysqld"
# Define the threshold for high CPU usage
cpu_threshold=99
echo "CPU Usage: $cpu_usage%"
# Check CPU usage
if (( $(awk -v cpu="$cpu_usage" -v threshold="$cpu_threshold" 'BEGIN {print (cpu >= threshold)}') )); then
echo "CPU Usage is high ($cpu_usage%)."
# Check if MySQL process is running
if pgrep -x "$mysql_process" > /dev/null; then
echo "MySQL is running."
# Restart MySQL
echo "Restarting MySQL due to high CPU usage..."
systemctl restart $mysql_service
echo "MySQL restarted."
else
echo "MySQL is not running."
fi
else
echo "CPU usage is below the threshold. No action taken."
# Check if MySQL process is running
if pgrep -x "$mysql_process" > /dev/null; then
echo "MySQL is running."
else
echo "MySQL is not running."
fi
fi
经测试,被短暂攻击时是管用的,被持续攻击时没用,重启完MySQL后,负载和CPU马上全红,一直持续。
目前只有宝塔的专业版防火墙中的CC增强模式管用,人机校验 要保持 一直开启 状态才行。Demand feedback