服务器负载和CPU占用100% 宝塔面板MySQL进程守护脚本
相信很多站长遇到服务器被打,服务器负载和CPU占用都是100%,网站502卡死,这时候Nginx,MySQL和php的服务都没有停止运行,站长自己还不知道网站打不开了。
因为Nginx,MySQL和php的服务都没有停止运行,所以那些守护程序都没起作用。
通过长期观察,网站被打,通常是MySQL占用太高,只有重启MySQL才有效,虽然频繁重启MySQL有可能造成数据崩溃,也没有其他办法。只有在被打的时候开启用一下,先保证网站能正常浏览再说。
今天网站又被打了,根据自身情况,写了个shell脚本,丢到宝塔计划任务中,测试几天看看效果。
当CPU使用率达到99%重启MySQL,或MySQL停止运行时重启MySQL,宝塔面板MySQL进程守护脚本,计划任务时间不要太短,先设置5分钟观察观察。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 |
#当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增强模式管用,人机校验 要保持 一直开启 状态才行。
由于网站搬家,部分链接失效,如无法下载,请联系站长!谢谢支持!
1. 带 [亲测] 说明源码已经被站长亲测过!
2. 下载后的源码请在24小时内删除,仅供学习用途!
3. 分享目的仅供大家学习和交流,请不要用于商业用途!
4. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
5. 本站所有资源来源于站长上传和网络,如有侵权请邮件联系站长!
6. 没带 [亲测] 代表站长时间紧促,站长会保持每天更新 [亲测] 源码 !
7. 盗版ripro用户购买ripro美化无担保,若设置不成功/不生效我们不支持退款!
8. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
9. 如果你也有好源码或者教程,可以到审核区发布,分享有金币奖励和额外收入!
10.如果您购买了某个产品,而我们还没来得及更新,请联系站长或留言催更,谢谢理解 !
GG资源网 » 服务器负载和CPU占用100% 宝塔面板MySQL进程守护脚本
1. 带 [亲测] 说明源码已经被站长亲测过!
2. 下载后的源码请在24小时内删除,仅供学习用途!
3. 分享目的仅供大家学习和交流,请不要用于商业用途!
4. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
5. 本站所有资源来源于站长上传和网络,如有侵权请邮件联系站长!
6. 没带 [亲测] 代表站长时间紧促,站长会保持每天更新 [亲测] 源码 !
7. 盗版ripro用户购买ripro美化无担保,若设置不成功/不生效我们不支持退款!
8. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
9. 如果你也有好源码或者教程,可以到审核区发布,分享有金币奖励和额外收入!
10.如果您购买了某个产品,而我们还没来得及更新,请联系站长或留言催更,谢谢理解 !
GG资源网 » 服务器负载和CPU占用100% 宝塔面板MySQL进程守护脚本