您的位置:首页 > 运维架构 > Shell

Shell应用 之 nginx 和 mysql 应用状态分析

2017-02-13 15:07 381 查看
check_server.sh

利用操作系统命令:

  网络命令: ping、nslookup、nm-tool、tracertroute、dig、telnet、nc、curl

  监控进程:ps、netstat、pgrep

利用客户端命令、工具:

  应用客户端:mysql、ab、mongo、php、jstack

  第三方工具包:nginxstatus、nagios-libexec

服务端接口支持:

  1、nginx - http_stub_status_module

  2、nutcracker监控集群(redis、memcache)状态

  3、Mongodb

  ……

1. 利用 shell 脚本分析 nginx 运行状态

#!/bin/bash
Resettem=$(tput sgr0)
Nginxserver='http://192.168.1.112'
Check_Nginx_Server()
{
Status_code=$(curl -m 5 -s -w %{http_code} ${Nginxserver} -o /dev/null)
if [ $Status_code -eq 000 -o $Status_code -ge 500 ];then
echo -e '\e[32m' "check http server error! Responce status code is:" $Resettem $Status_code
else
Http_content=$(curl -s ${Nginxserver})
echo -e '\e[32m' "check http server ok! \n" $Resettem $Http_content
fi
}

Check_Nginx_Server
~
~
~
"check_server.sh" 15L, 460C


2.监控Mysql主从复制状态

  


  1. 搭建主从复制环境

  2. 基于mysql客户端连接,获取主从复制状态

    mysql > show slave status\G;

      Slave_IO_Running-IO 线程是否有连接到主服务器上

      Seconds_Behind_Master - 主从同步的延时时间

3. Mysql 还没学过,先暂行放下,脚本仅实现Mysql是否连接成功

#!/bin/bash
Resettem=$(tput sgr0)
Nginxserver='http://192.168.1.112'
Mysql_Slave_Server='192.168.1.112'
Check_Nginx_Server()
{
Status_code=$(curl -m 5 -s -w %{http_code} ${Nginxserver} -o /dev/null)
if [ $Status_code -eq 000 -o $Status_code -ge 500 ];then
echo -e '\e[32m'"Check http server error! Responce status code is:" $Resettem $Status_code
else
Http_content=$(curl -s ${Nginxserver})
echo -e '\e[32m'"Check http server ok! \n" $Resettem $Http_content
fi
}

Check_Mysql_Server()
{
nc -z -w2 ${Mysql_Slave_Server} 3306 &>/dev/null
if [ $? -eq 0 ];then
echo -e '\e[32m'"Connect ${Mysql_Slave_Server} OK!"'\033[0m'
fi
}

Check_Nginx_Server
Check_Mysql_Server


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: