平时的开发中,如果没有专门的服务器监测系统,有时候系统出现状况,比如端口被占用了,某个服务挂掉了,磁盘满了,内存不足了等等,都会导致服务不可用的问题。有的时候影响了很多事情,但是你的注意点却不能时刻都在服务器上,毕竟要专注业务开发。
废话不多说,给个解决方案:
方案一:自己定好每天的闹钟,到点就去服务器手动看看健康状态。(一看就是老玩家了)
方案二:引入服务器监测系统,例如wgcloud等,但是个人觉得太笨重,对于普通的服务器来说增加了不小的资源开销,反而适得其反。(氪金玩家)
方案三:通过linux的定时任务,执行脚本,把服务器自己需要监测的一些数据通过shell、python等脚本发送到邮箱,提醒自己记得关注。
实现方案三:
1、准备shell脚本采集数据
此处举例:shell采集服务器的内存使用情况和磁盘使用情况,实际情况中根据自己的需要编写shell
#! /bin/bash
mem_limit=0 #内存阈值,值根据自己情况设定
io_limit=0 #磁盘使用阈值,值根据自己情况设定
function monitor_mem(){
mem_total=`free -m |awk 'NR==2{print $2}'`
mem_use=`free -m |awk 'NR==2{print $3}'`
mem_per=`echo "scale=2;$mem_use/$mem_total" |bc -l|cut -d. -f2`
df -h --total > /monitor/monitor_IO.log
io_total=`cat monitor_IO.log | awk 'END {print}' |awk {'print $2}'`
io_used=`cat monitor_IO.log | awk 'END {print}' |awk {'print $3}'`
io_avil=`cat monitor_I