Acompanhar status de uma replicação MySQL
Publicado por Matheus (última atualização em 25/02/2013)
[ Hits: 6.165 ]
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()
Backup automatizado de toda a base MySQL
Dígito verificador, módulo 11 simples, para uso interno no "postgresql" como
Dump MySQL com relatório de logs por e-mail
Nenhum comentário foi encontrado.
Como rodar o Folding@home no Linux
Criando um painel de controle (Dashboard) para seu servidor com o Homepage
O Abismo entre o Código e o Chão: Saltos Tecnológicos e a Exclusão Estrutural no Brasil
Instalar e Configurar a santíssima trindade (PAP) no Void Linux
NixOS + NVIDIA antiga: como sobreviver ao driver 595 (GTX 750 Ti / Maxwell)
Conhecendo o tmux: Multiplexador de Terminal
Acessando página do Syncthing fora da máquina local
[Resolvido] Meu monitor suporta 100fps. Por que o máximo é 60fps nos jogos?
Qual melhor distro para esse notebook? (1)
Ativação de som 5.1 e nvidia (0)
Entrevista com Greg Kroah-Hartman (2)









