平常管理03-監控MYSQL主從延時3秒腳本;

#!/bin/env python
# -*- encoding: utf-8 -*-
import time
import os
import sys
import json
import re
import thread
mysql_stat_list = []
class MySQLMonitorInfo():
      def __init__(self):
            pass
      def is_slave(self):
            m = "mysql -e 'SHOW Slave status\G' "
            data = os.popen(m).readlines()
            if data == []:
               return '',False
            else:
                return data,True
      def stat_info(self):
           data,isslave = self.is_slave()
           if is slave:
                Str_string = {}
                for d in data[1:]:
                ds = d.replace("  ","").replace("\t","").split(":")
                Str_string[ds[0].strip()] = ds[1].strip()
                #print Str_string
                result = {
                'name': '%s' % ('slave.iorun'),
                'groups': "MysqlDelay3",
                'value': 1 if Str_string['Slave_IO_Running'] == 'Yes' else 2,
                'status': 1 if Str_string['Slave_IO_Running'] == 'Yes' else 2,
                'command': sys.argv[0],
                'messages': "%s %s"%('Slave_IO_Running', '正常' if Str_string['Slave_IO_Running'] == 'Yes' else "中止"),
                }
                mysql_stat_list.append(result)
                result = {
                'name': '%s' % ('slave.delay3'),
                'groups': "MysqlDelay3",
                'value': Str_string['Seconds_Behind_Master'],
                'status': 1 if int(Str_string['Seconds_Behind_Master']) < int(sys.argv[1]) else 2,
                'command': sys.argv[0],
                'messages': "%s %s"%('Seconds_Behind_Master', Str_string['Seconds_Behind_Master']),
                }
                mysql_stat_list.append(result)
                result = {
                'name': '%s' % ('slave.sqlrun'),
                'groups': "MysqlNew",
                'value': 1 if Str_string['Slave_SQL_Running'] == 'Yes' else 2,
                'status': 1 if Str_string['Slave_SQL_Running'] == 'Yes' else 2,
                'command': sys.argv[0],
                'messages': "%s %s"%('Slave_SQL_Running', "正常" if Str_string['Slave_SQL_Running'] == 'Yes' else "中止"),
                }
                return mysql_stat_list.append(result)
                else:
                      return {}
        def get_data(host,tid):
            return MySQLMonitorInfo().stat_info()
       if len(sys.argv) > 4:
          for host in sys.argv[1].split(","):
              thread.start_new_thread(get_data, (host, 1))
          else:
              get_data("", "")
              print json.dumps(mysql_stat_list)
相關文章
相關標籤/搜索