网站优化

网站优化

Products

当前位置:首页 > 网站优化 >

服务器负载和CPU占用100% 宝塔面板MySQL进程守护脚本

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