博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
get_slave_status.py
阅读量:6678 次
发布时间:2019-06-25

本文共 1948 字,大约阅读时间需要 6 分钟。

#!/usr/bin/env python

#-*- encoding: utf8 -*-
import mysql.connector
import get_mysql_conn_info
    
"""
SHOW SLAVE STATUS命令输出内容
"""
class GetSlaveResult:
    """
    getdbconfig 参数是一个列表,第一列是IP,第二列是账号,第三列是密码,第四列是端口号。
    """   
    def __init__(self,getdbconfig):       
        self.getdbconfig = getdbconfig
         
    """
    获取 SHOW SLAVE STATUS 输出结果
    """
    def get_slave_status(self):
        dbconfig = self.getdbconfig
        for i in range(int(len(dbconfig))):                           
            show_slave_status = "SHOW slave STATUS;"        
            cnn = mysql.connector.connect(host=dbconfig[i][0] ,user=dbconfig[i][1] ,password=dbconfig[i][2] ,port=dbconfig[i][3])
            cursor = cnn.cursor(dictionary=True)
            cursor.execute(show_slave_status)
            result_fet = cursor.fetchall()
            result = result_fet[0]
            result["checkmysql_host"] = dbconfig[i][0]
            result["checkmysql_user"] = dbconfig[i][1]
            result["checkmysql_port"] = int(dbconfig[i][3])
            return result        
                                                     
    """
    检查SHOW SLAVE STATUS状态
    """
    def check_slave_status(self):
        check_ture_false_slave_status = True
        result = self.get_slave_status()
        if result.get('Slave_IO_Running') == 'Yes' and result.get('Slave_SQL_Running') == 'Yes':
            pass
        else:
            check_ture_false_slave_status = False
        print  "主机名: %s , 端口号: %s , Slave_IO_Running 状态 = %s , Slave_SQL_Running 状态 = %s " %(str(result.get('checkmysql_host')),str(result.get('checkmysql_port')),str(result.get('Slave_IO_Running')),str(result.get('Slave_SQL_Running')))
 
    """
    获取Last_SQL_Error内容
    """
    def get_last_sql_error(self):
        check_ture_false_last_sql_error = True
        result = self.get_slave_status()     
        if result.get('Last_SQL_Error')== '':
            pass
        else:
            check_ture_false_last_sql_error = False
        print  "主机名: %s , 端口号: %s , Last_SQL_Error 内容 = %s " %(str(result.get('checkmysql_host')),str(result.get('checkmysql_port')),str(result.get('Last_SQL_Error')))
                
checkdbconfig = get_mysql_conn_info.GetConn('/data/lgj/dblist.xlsx').get_csv()
print_result = GetSlaveResult(checkdbconfig)
print_result.check_slave_status()
print_result.get_last_sql_error()
 

转载于:https://www.cnblogs.com/liang545621/p/7616032.html

你可能感兴趣的文章
学生——成绩表查询
查看>>
Faster-rnnlm代码分析3 - EvaluateLM(前向计算ForwardPropagate)
查看>>
Python4周 入职培训的过程
查看>>
Linux 下的下载文件命令
查看>>
hibernate generator class=xxx id详解
查看>>
关于安装黑苹果
查看>>
Sublime Text 3 安装
查看>>
spring源代码分析
查看>>
分析UIWindow
查看>>
hibernate 批量处理数据
查看>>
Redis时延问题分析及应对
查看>>
HDU 4915 Parenthese sequence _(:зゝ∠)_ 哈哈
查看>>
I.MX6 修改调试串口号(ttymx0 -> ttymxc2)
查看>>
mips cfe命令
查看>>
[转]Spring数据库读写分离
查看>>
TELNET协议规范
查看>>
View and Data API Tips : Conversion between DbId and node
查看>>
如何不给红包就看朋友圈照片?get✔️
查看>>
金额显示,每3位加逗号
查看>>
第四话-开放封闭原则
查看>>