Herramientas de usuario

Herramientas del sitio


manuales:nagios:capacitacion:tipos_de_notificaciones

Diferencias

Muestra las diferencias entre dos versiones de la página.

Enlace a la vista de comparación

Ambos lados, revisión anteriorRevisión previa
Próxima revisión
Revisión previa
Última revisiónAmbos lados, revisión siguiente
manuales:nagios:capacitacion:tipos_de_notificaciones [2015/09/18 17:45] – [SMS] cayumanuales:nagios:capacitacion:tipos_de_notificaciones [2018/07/24 15:56] – [WhatsApp (Dependencia externa sin garantía)] cayu
Línea 1: Línea 1:
 ====== Tipos de notificaciones ====== ====== Tipos de notificaciones ======
 +==== Definiciones previas  ====
 +  * **Indicador**: //Dato o información que sirve para conocer o valorar las características y la intensidad de un hecho o para determinar su evolución futura.//
 +  * **Alerta**: //Señal o aviso con el objetivo de desviar la atención hacia el dato obtenido del indicador.//
 +  * **Notificación**: //Hacer saber una cosa a alguien siguiendo ciertas formalidades.//
 +  * **Criterio**: //Opinión, juicio o decisión que se adopta sobre una cosa.//
 +
 +
 ===== Correo electrónico ===== ===== Correo electrónico =====
 +Para el envío de notificaciones por parte de Nagios es necesario configurar un MTA (Agente de Transporte de Correos), por lo general suele estar previamente configurado el Sendmail en el caso de que nos basemos en un CentOS, o un Postifx tratándose de un SuSE o Debian.
 +
 +En caso de que utilizemos el paquete de Postfix disponible en la distribución, y debamos utilizar otro servidor saliente SMTP dentro de la red, deberemos configurar el relayhost apuntando al servidor SMTP de la red local ej 192.168.1.110, quedando el archivo /etc/postfix/main.cf con las siguientes entradas de configuración.
 +
 +<code>
 +queue_directory = /var/spool/postfix
 +command_directory = /usr/sbin
 +daemon_directory = /usr/lib/postfix
 +mail_owner = postfix
 +myhostname = nagios
 +mydomain = midominio.net
 +inet_interfaces = $myhostname
 +unknown_local_recipient_reject_code = 550
 +debug_peer_level = 2
 +debugger_command =
 +         PATH=/bin:/usr/bin:/usr/local/bin:/usr/X11R6/bin
 +         xxgdb $daemon_directory/$process_name $process_id & sleep 5
 +sendmail_path = /usr/sbin/sendmail
 +newaliases_path = /usr/bin/newaliases
 +mailq_path = /usr/bin/mailq
 +setgid_group = maildrop
 +html_directory = /usr/share/doc/packages/postfix/html
 +manpage_directory = /usr/share/man
 +sample_directory = /usr/share/doc/packages/postfix/samples
 +readme_directory = /usr/share/doc/packages/postfix/README_FILES
 +mail_spool_directory = /var/mail
 +canonical_maps = hash:/etc/postfix/canonical
 +virtual_maps = hash:/etc/postfix/virtual
 +relocated_maps = hash:/etc/postfix/relocated
 +transport_maps = hash:/etc/postfix/transport
 +sender_canonical_maps = hash:/etc/postfix/sender_canonical
 +masquerade_exceptions = root
 +masquerade_classes = envelope_sender, header_sender, header_recipient
 +program_directory = /usr/lib/postfix
 +inet_interfaces = 192.168.1.4
 +masquerade_domains = 
 +mydestination = $myhostname, localhost.$mydomain
 +defer_transports = 
 +disable_dns_lookups = no
 +relayhost = 192.168.1.110
 +content_filter = 
 +mailbox_command = 
 +mailbox_transport = 
 +smtpd_sender_restrictions = hash:/etc/postfix/access
 +smtpd_client_restrictions = 
 +smtpd_helo_required = no
 +smtpd_helo_restrictions = 
 +strict_rfc821_envelopes = no
 +smtpd_recipient_restrictions = permit_mynetworks,reject_unauth_destination
 +smtp_sasl_auth_enable = no
 +smtpd_sasl_auth_enable = no
 +smtpd_use_tls = no
 +smtp_use_tls = no
 +alias_maps = hash:/etc/aliases
 +mailbox_size_limit = 0
 +message_size_limit = 10240000
 +</code>
 +
 +Siendo los parámetros : **inet_interfaces** //la ip propia por cual salir, si tenemos una sola placa de red, pondremos esa ip//, **relayhost** //es el host que nos realizará el envío SMTP//.
 ===== SMS ===== ===== SMS =====
 Podemos configurar alertas SMS de forma muy simple con el software Gnokii. Podemos configurar alertas SMS de forma muy simple con el software Gnokii.
Línea 56: Línea 122:
 {{:manuales:nagios:nagios_sms.svg.gz|}} {{:manuales:nagios:nagios_sms.svg.gz|}}
 ===== WhatsApp (Dependencia externa sin garantía) ===== ===== WhatsApp (Dependencia externa sin garantía) =====
 +  * https://github.com/tgalal/yowsup
 +===== Telegram =====
 +<code python>
 +#!/usr/bin/env python
 +
 +import argparse
 +from twx.botapi import TelegramBot
 +
 +def parse_args():
 +    parser = argparse.ArgumentParser(description='Nagios notification via Telegram')
 +    parser.add_argument('-t', '--token', nargs='?', required=True)
 +    parser.add_argument('-o', '--object_type', nargs='?', required=True)
 +    parser.add_argument('--contact', nargs='?', required=True)
 +    parser.add_argument('--notificationtype', nargs='?')
 +    parser.add_argument('--hoststate', nargs='?')
 +    parser.add_argument('--hostname', nargs='?')
 +    parser.add_argument('--hostaddress', nargs='?')
 +    parser.add_argument('--servicestate', nargs='?')
 +    parser.add_argument('--servicedesc', nargs='?')
 +    parser.add_argument('--output', nargs='?')
 +    args = parser.parse_args()
 +    return args
 +
 +def send_notification(token, user_id, message):
 +    bot = TelegramBot(token)
 +    bot.send_message(user_id, message).wait()
 +
 +def host_notification(args):
 +    state = ''
 +    if args.hoststate == 'UP':
 +        state = u'\U00002705 '
 +    elif args.hoststate == 'DOWN':
 +        state = u'\U0001F525 '
 +    elif args.hoststate == 'UNREACHABLE':
 +        state = u'\U00002753 '
 +
 +    return "%s%s (%s): %s" % (
 +        state,
 +        args.hostname,
 +        args.hostaddress,
 +        args.output,
 +    )
 +
 +def service_notification(args):
 +    state = ''
 +    if args.servicestate == 'OK':
 +        state = u'\U00002705 '
 +    elif args.servicestate == 'WARNING':
 +        state = u'\U000026A0 '
 +    elif args.servicestate == 'CRITICAL':
 +        state = u'\U0001F525 '
 +    elif args.servicestate == 'UNKNOWN':
 +        state = u'\U00002753 '
 +
 +    return "%s%s/%s: %s" % (
 +        state,
 +        args.hostname,
 +        args.servicedesc,
 +        args.output,
 +    )
 +
 +def main():
 +    args = parse_args()
 +    user_id = int(args.contact)
 +    if args.object_type == 'host':
 +        message = host_notification(args)
 +    elif args.object_type == 'service':
 +        message = service_notification(args)
 +    send_notification(args.token, user_id, message)
 +
 +if __name__ == '__main__':
 +    main()
 +</code>
 +  * https://github.com/pommi/telegram_nagios
 ===== Visual general ===== ===== Visual general =====
 +
 +En determinadas situaciones necesitamos visualizar información de forma simple, para poder comunicar a personal no técnico y que dicha información sea exacta, clara y veraz. La finalidad principal de esto, es que todos el que visualice dicha información se de por notificado de la situación que se presenta.
 +
 +Los datos suministrados deben ser fáciles de identificar y preferentemente deben estar asociados a un servicio que puedan individualizar todos o la mayoria de los miembros de la organización.
 +
 +La mayoría de las organizaciones optan por una pantalla gigante en la cual, quien pase frente a ella se de por anoticiado de la situación actual.
 +
 +Para cumplir eficazmente con el objetivo de notificar la información a todos los miembros de la organización, el lenguaje visual debe ser claro y preciso. Se deben omitir todos los detalles irrelevantes para el usuario no ténico y se deben proveer informaciones relevantes, como ubicación geográfica, servicios afectados, y datos de contacto en sitio.
 +
 +
 {{ :manuales:nagios:screen_nagios.png?680 |}} {{ :manuales:nagios:screen_nagios.png?680 |}}
 {{ :manuales:nagios:screen_nagvis.png?680 |}} {{ :manuales:nagios:screen_nagvis.png?680 |}}
manuales/nagios/capacitacion/tipos_de_notificaciones.txt · Última modificación: 2019/03/26 20:25 por cayu