欢迎光临
我们一直在努力

监控mysql数据库主从状态

python版本2.6.6

#!/usr/bin/python

import MySQLdb

def check_mysql():
    status = True
    try:
        conn=MySQLdb.connect(host=’172.7.10.8′,user=’summer’,passwd=’summer’,db=’cms’)
        cur=conn.cursor()
        cur.execute(“show slave status;”)
        result = cur.fetchall()
        io_thread=result[0][10]
        sql_thread=result[0][11]
        #print io_thread,sql_thread
        cur.close()
        conn.close()
        status = True
        if io_thread == “Yes” and sql_thread == “Yes”:
            print ‘2’
            status = True
        else:
            print ‘0’
            status = False
    except Exception,e:
        print Exception,”:”,e

go = check_mysql()

听大神的修改后代码:

#!/usr/bin/python

import MySQLdb

def check_mysql():
    try:
         conn=MySQLdb.connect(host=’172.7.10.8′,user=’summer’,passwd=’summer’,

        db=’cms’)

        cur=conn.cursor(MySQLdb.cursors.DictCursor)
        cur.execute(‘show slave status’)
        result=cur.fetchall()
        if result is None:
            raise EnvironmentError(‘result is None’)
        slave_status=result[0]
        io_thread=slave_status.get(‘Slave_IO_Running’)
        sql_thread=slave_status.get(‘Slave_SQL_Running’)
        if io_thread == “Yes” and sql_thread == “Yes”:
            print ‘it is status ok’
        else:
            print ‘io_status is %s \nsql_status is %s’ %(io_thread,sql_thread)

    finally:
        cur.close()
        conn.close()

if __name__ == ‘__main__’:
    check_mysql()
~

赞(0)
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。