Acompanhar status de uma replicação MySQL
Publicado por Matheus (última atualização em 25/02/2013)
[ Hits: 5.641 ]
Homepage: matheusrosa.com.br
Download check_slave_server.py
Este script serve para monitorar o status de uma replicação MySQL.
Tal script deve ser configurado no crontab. Segue a regra para ser executado a cada 30min:
*/30 * * * * python27 /check_slave_server.py
# -*- coding: utf-8 -*- """ Script to monitor a replication slave server mysql @author: Matheus Rosa <matheusdsrosa@gmail.com> @date: 2013-01-10 """ from email.MIMEMultipart import MIMEMultipart from email.MIMEBase import MIMEBase from email.MIMEText import MIMEText from email.Utils import COMMASPACE, formatdate from email import Encoders import datetime,smtplib,os import subprocess import re import socket import fcntl import struct #MYSQL MYSQL_USER = 'seuusuario' MYSQL_PASSWD = 'suasenha' # EMAIL FROM = "suporte@seuhost.com.br" SMTP_SERVER = 'smtp.gmail.com' SMTP_PORT = 587 TO = ['usuario@seuhost.com.br'] AUTH_EMAIL = "usuario@gmail.com" AUTH_PASS = "senha" def get_ip_address(ifname): """ Returns the ip of the machine from which the script is running """ s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) return socket.inet_ntoa(fcntl.ioctl( s.fileno(), 0x8915, # SIOCGIFADDR struct.pack('256s', ifname[:15]) )[20:24]) def get_slave_status(format_type='txt'): """ Returns the plain/text message of the slave servers's current status """ command = ["mysql", "-u%s" % MYSQL_USER, "-p %s" % MYSQL_PASSWD, "-e show slave status"] if format_type == 'html': command.append("-H") output = subprocess.check_output(command) return output def slave_status_is_ok(): """ Runs a mysql command that returns a plain/text message of the slave server's current status. Then, searches for 2 occurrences of the word 'Yes' in that message. If there is 2 occurrences, it means that slave server is fine, otherwise, its fucked up. """ output = get_slave_status() occurrences = [m.start() for m in re.finditer('Yes', output)] return (len(occurrences) == 2) def send_email_notification(send_to, subject, text): """Sends a email""" assert type(send_to)==list msg = MIMEMultipart() msg['From'] = FROM msg['To'] = COMMASPACE.join(send_to) msg['Date'] = formatdate(localtime=True) msg['Subject'] = subject part = MIMEBase("text", "html") part.set_payload(text) msg.attach(part) mailServer = smtplib.SMTP(SMTP_SERVER, SMTP_PORT) mailServer.ehlo() mailServer.starttls() mailServer.ehlo() mailServer.login(AUTH_EMAIL, AUTH_PASS) mailServer.sendmail(FROM, send_to, msg.as_string()) mailServer.close() if __name__ == '__main__': now = datetime.datetime.now() text = get_slave_status(format_type='html') slave_status_log = open("slave_status.log", "a") server = get_ip_address('eth0') if not slave_status_is_ok(): msg = '[%s] Slave server %s\'s replication is NOT ok!' % (now, server) msg += '\nSending a email notification to %s' % (','.join(TO)) send_email_notification(TO, 'Replication Server (%s): An error occurred!' % server, text) else: msg = '[%s] Slave server %s\'s replication is fine.\n' % (now, server) slave_status_log.write(msg) slave_status_log.close()
Dump MySQL com relatório de logs por e-mail
Backup automatizado de toda a base MySQL
yFone - Yes, outra agenda telefonica escrita em python! ;- )
Python com CouchDB usando couchdbkit
Nenhum comentário foi encontrado.
Passkeys: A Evolução da Autenticação Digital
Instalação de distro Linux em computadores, netbooks, etc, em rede com o Clonezilla
Título: Descobrindo o IP externo da VPN no Linux
Armazenando a senha de sua carteira Bitcoin de forma segura no Linux
Enviar mensagem ao usuário trabalhando com as opções do php.ini
Como configurar posicionamento e movimento de janelas no Lubuntu (Openbox) com atalhos de teclado
Máquinas Virtuais com IP estático acessando Internet no Virtualbox
Instalar o Microsoft Edge no Slackware 15
Instalando Brave Browser no Linux Mint 22
vídeo pra quem quer saber como funciona Proteção de Memória:
Formatando cartão de memoria que nao formata[AJUDA] (18)
Primeira vez utilizando Linux Ubuntu 22.04 e já tenho problemas… (5)
warsaw parou de funcionar após atualização do sistema (solução) (1)
Separar trafego da VPN da VPS (0)
Desde que seja DDR3, posso colocar qualquer memória? [RESOLVIDO] (6)