检查服务器健康状况的办法有几种
1. 检查进程是否存在
使用 ps 命令即可
ps aux | grep xxxx
2. 检查端口号
netstat -antp | grep xxxx
但是有时服务器处理假死状态,即进程存在同时也监听了端口但是不处理任何消息。这里可以使用第三种方法。
3. 访问web服务器的api,查看http状态码
这里使用 curl 命令, 不懂curl的可以百度一下这里不做详细的解释了。
curl -o /dev/null -s -w %{http_code} www.baidu.com
以上命令可以取得http状态码。 返回200表示服务器能够正常处理请求,否则既是有问题。
下面利用shell脚本批量检查服务器是否宕机或者假死,话不多说直接上代码。
这里有2个文件
watch.sh
#!/bin/bash
for file in `cat domain.txt`
do
for loop in `seq 1 30`
do
rs=`curl -o /dev/null -s -w %{http_code} $file`
echo "$file result -> $rs"
urlresponse=${file}" -> "${rs}
if [ $rs -eq 200 ]; then
urlresponse=$urlresponse"\n"
break
else
urlresponse=$urlresponse" error\n"
fi
sleep 2
done
result=${result}${urlresponse}
done
echo -e "\n-------------------"
echo -e $result
domain.txt
http://xxx.xxx.xxx.xxx:8080/xxx.jsp
http://xxx.xxx.xxx.xxx:9080/xxx.jsp
http://xxx.xxx.xxx.xxx:8080/xxx.jsp
#http://xxx.xxx.xxx.xxx:8080/xxx.jsp
#http://xxx.xxx.xxx.xxx:8080/xxx.jsp
watch.sh 读取 domain.txt 中的地址,每个地址每隔2秒请求一次循环30次。判断 http_code 是否返回 200, 如果是的则检查下一个地址。全部检查完之后输出汇总结果。如需增加需要检查的服务器,在domain.txt 中添加即可。