Parceros
  • 👽Recursos
    • 💻Nodos validadores
      • Buenas prácticas y seguridad de un validador
      • Montaje de nodo validador de Stargaze
      • Montaje de nodo validador de Tgrade
      • Montaje de nodo validador de Juno
      • Instalacion del Cosmovisor
      • Instalación de AutoCompound
      • Guía de instalación Prometheus y Grafana para un Validador
    • 🎓Desarrollo
      • Fundamentos en Gnu/Linux
      • Fundamentos en Blockchain
      • Billeteras
      • Introducción a Cosmos Hub
      • Guia de Inicio en Rust
      • Clases de CosmWasm
        • Introducción a CosmWasm
        • Puntos de entrada de un contrato vacio
        • Consultas - Query
      • Clases de Rust
        • Introducción a Rust
        • Ciclos
        • Funciones
        • Manejo de la memoria
        • Tipos de datos avanzados
        • Macros
        • Manejo de paquetes
        • Manejo de errores
      • Guia Archway
        • Instalación de requisitos
        • Configuración del proyecto
        • Solicitud de tokens Testnet
        • Mi primera app
          • Configuracion
          • Produciendo ejecutables wasm
          • Despliegue e instanciación de contratos en la cadena
          • Interactuar con su contrato
          • Construir el frontend de la dApp
        • Proyecto NFT
          • Creando un proyecto NFT
          • Despliegue del contrato de tokens
          • Acuñación y envío de tokens
          • Construye la Dapp NFT
        • Fee Grant
          • Comprendiendo los Fee grant
          • Grant asignación
          • Utilizando asignaciones grant
        • Multifirmas
          • Archway multi firma hub
          • Navegar por la interfaz multi firmas
      • Cosmwasm Documentacion
        • Introducción
        • Primeros pasos
          • Introducción
          • Configuración del entorno
          • Elaborar un contrato
          • Test Unitarios
          • Despliegue e interacción
          • Integración con contratos inteligentes
          • Próximos pasos
        • Arquitectura
          • ¿Qué son los contratos multicadena?
          • Modelo de actor para las convocatorias de contratos
          • Nombres y direcciones
          • Consulta del estado del contrato
          • Formatos de serialización
          • Composición del contrato
          • Comparación con los contratos de solidity
        • Contratos inteligentes
          • Semántica contractual
          • Message
            • Messages
            • Submensajes
          • State
            • Simple state
            • Complex state y maps
          • Result y option
          • Entry points
          • Query
          • Events
          • Math
          • Verificación de contratos inteligentes
          • Migration
          • Migrar una dapp a una red diferente
          • Testing
          • Ejecución Sudo
          • CosmWasm y CIB
        • Tutoriales
          • Opcion simple
            • Testing
          • Storage
            • ¿Cómo funciona el almacenamiento de valores clave?
            • Índices
            • Modelización avanzada de estados
          • Cosmwasm con ejemplos
            • Operaciones matemáticas de Cosmowasm
            • Crear una instancia de un contrato CosmWasm
            • Timelock
            • Contrato Crowdfunding
            • Respuestas y atributos en Cosmwasm
            • Lee y escribe
            • Envío de tokens
            • Token Vaults
            • Creador de mercado automático de productos constantes (AMM)
      • Guia Celestia
        • Descripcion general de celestia
          • Introduccion
          • Blockchains monolíticos vs modulares
          • Capa de disponibilidad de datos
            • La capa de disponibilidad de datos de Celestia
            • El ciclo de vida de una transacción celestia-app
            • Recuperabilidad de datos y poda
            • Disponibilidad de datos FAQ
          • Recursos adicionales
            • Aprende modular
            • Glosario de Celestia
            • Especificaciones de aplicación de celestes
            • Documentación API de nodo celestial
        • Ejecutar un nodo
          • Descripción general de los nodos en ejecución en Celestia
          • Guía de inicio rápido
            • Decidir qué nodo ejecutar
            • Entorno de desarrollo
            • Instalar celestia-node
            • Instalar celestia-app
            • 🐳 Configuración de Docker
          • Redes
            • Resumen de redes
            • Mainnet Beta
            • Mocha testnet
            • Arábica devnet
          • Tipos de nodos
            • Disponibilidad de datos
              • Nodo ligero
              • Nodo completo
              • Nodo puente
            • Consenso
            • Relay de IBC
              • Guía de retransmisión IBC
              • Relays de IBC
          • Recursos
            • nodo-celestia
              • Metricas
              • guía config.toml
              • Redes y valores personalizados
              • Solución de problemas
            • celestia-app
              • Especificaciones
              • Métricas, visualización y alertas
              • Mecánica de corte
              • Crear un testnet Celestia
              • Comandos CLI útiles
              • Monitor de Actualización
              • Carteras en celestia-app
              • Multisig
              • Crea una cuenta de adquisición
            • SystemD
            • Proceso de hardfork
        • Desarrolladores
          • Construir modular
          • Envío de blobs de datos a Celestia
          • Directrices de reenvío de transacciones
          • API de nodo
            • Celestia-node RPC CLI tutorial
            • Documentación de la API RPC de Celestia-Node
            • Rápido Scavenger
            • Page
          • Integrar con Blobstream
            • Descripción general de Blobstream
            • Integrarse con contratos de Blobstream
            • Integrar con el cliente Blobstream
            • Consultando las pruebas de Blobstream
            • Operadores locales de Blobstream X
              • Solicitar rangos de compromiso de datos
              • Nuevas implementaciones de Blobstream X
          • Implementar un rollup
            • L2s Ethereum
              • Ethereum fallback
              • Arbitro
                • Introducción a los rollups de Arbitrum con Celestia como DA
                • Implementar un arbitrum rollup devnet
                • Testnet de nitrógeno
                • Implementar un contrato inteligente sobre la implementación de Arbitrum
                • Implemente un dapp en su devnet Arbitrum rollup
                • Optimismo
                  • Introducción a la integración de OP Stack
                  • Bubs testnet
                  • Implemente un contrato inteligente en Bubs testnet
                  • Implemente un dapp en Bubs testnet
                  • Implemente un devnet OP Stack
                  • Implemente un devnet OP Stack en Celestia
                  • Auditoría
                  • Implemente un dapp con thirdweb
                  • Rollups-as-a-Servicio
                    • Caldera
            • Rollkit
            • Astria
              • Documentación
              • Implementar a Dusknet
            • SDK Soberano
            • Vistara
            • Dimensión
          • Carteras
            • Crea una billetera con celestia-node
            • Integraciones de billeteras con Celestia
          • Integre Celestia para proveedores de servicios
      • Unión
        • Arquitectura
          • CometBLS
          • Galois
          • Voyager
        • Conceptos
          • BLS Firmas
          • Clientes de Luz Condicional
          • Verificación de Consenso
          • Tecnología de validador distribuido
          • IBC
          • Sin permiso versus sin confianza
        • Infraestructura
          • Operador de nodo
            • Empezando
            • Docker Compose
            • Kubernetes
            • NixOS
            • Configuración del Nodo
        • Integracion
          • IBC Enabled Solidity
        • Demostrar
          • Dirigiendo el Union Devnet
          • PingPong
        • Unirse al testnet
          • Empezando
          • Ejecutar el binario cliente
          • Ejecución de Unionvisor
          • Obteniendo Tokens Testnet
          • Crear un Validador
          • Endpoints publicos
          • Sincronización de estado
          • Liberar un validador
          • Preguntas frecuentes
          • Historial de actualizaciones
        • Guia de estilo
          • Lista de palabras
      • Avail
        • Introducción a Avail
          • Aprovechar DA
          • Aprovechar Nexus
          • Aprovechar la fusión
        • Informacion de red
        • Más información sobre disponibilidad
          • El conseso
            • BABE
            • GRANDPA
            • NPoS
          • EIP-4844 y disponible
        • Guia de nuevo usuario
          • Cómo crear y administrar una cuenta disponible
          • Cómo utilizar el Explorador Goldberg Testnet
          • Cómo utilizar el faucet Testnet
          • Cómo establecer una identidad en cadena
          • Cómo generar una identificación de aplicación disponible
          • Cómo realizar transferencias de saldo disponibles
          • Cómo crear grupos de nominaciones disponibles
        • Construir con disponibilidad
          • Cree un paquete acumulativo con Avail
          • Comience con Avail
          • Optimium
            • OP Stack
            • Aprovechando la pila OP con Avail
            • Cómo utilizar la pila OP con Avail
            • Adaptador de pila OP 🔗
          • Validium
            • Polygon zkEVM
              • Construyendo sobre Polygon zkEVM con Avail
              • Cómo utilizar Polygon zkEVM con Avail
              • Nodo Validium 🔗
              • Contratos de Validium 🔗
              • Puente Validium 🔗
            • Madara Starknet
              • Construyendo sobre Madara Stack con Avail
              • Cómo utilizar Madara con Avail
              • Madara Starknet🔗
            • Referencia
          • Sovereign Rollups
            • Sovereign SDK 🔗
            • Rollkit 🔗
            • OpEVM 🔗
        • Glosario
        • Preguntas generales frecuentes
      • Dymension
        • Aprender
          • ELI5
          • RollApps
            • RollApps
            • Tokens
            • Gobernancia
            • Puente
            • En profundidad
              • Dymension RDK
                • Dymint
              • Gobernanza
                • Gobernador
                  • Descripción general
                  • Crear gobernador
                  • Otros comandos
                • Votación
                  • Parámetros ajustables
                  • Gasto comunitario
                  • Registro de tokens ERC-20
              • IBC Puente
                • Visión general
                • Seguridad
                • Retransmisores
          • Dymension
            • Visión general
            • DYM
              • Supply
              • Demanda
              • Crecimiento
              • Distribución
            • Seguridad
              • Estándares
              • Actualizable
              • Disponibilidad de datos
              • Pruebas de fraude
              • Resistencia a la censura
              • Page 1
            • Puentes
              • IBC
              • eIBC
            • Liquidez
              • Descripción general
              • Depositar tokens
              • Vinculación de tokens LP
              • Incentivos
              • Comisiones
            • Gobernanza
              • Descripción general
              • Preparando una propuesta
              • Proponiendo a la dimocracia
        • Construir
          • Descripción general
          • Testnet
            • EVM
              • Descripción general
            • CosmWasm
              • Descripción general
              • Información
              • Ejemplo de cosmoWasm
          • Roller CLI
            • Descripción general
            • Comenzar
              • Instalar
              • Inicializar RollApp
              • Registro
              • Correr
                • Simple
                • Avanzado
                  • Cliente ligero DA
                  • Secuenciador
                  • Retransmisor
            • Nodo en ejecución
              • Ejecutando en producción
              • Supervisión
              • Información de RollApp
              • Exportar claves
              • Mejora
              • Editar la configuración de RollApp
              • Sincronización de estado
            • Solución de problemas
              • Descripción general
              • Saldos
              • Hardware
              • Rollapp de importación/exportación
              • Acceso externo
              • Estado
              • Archivos de registro
            • RollApp local
              • Ejecute la aplicación EVM RollApp
              • Ejecute la aplicación CosmWasm RollApp
        • Validar
          • Preguntas frecuentes sobre nodos
          • Construir dimensión
          • Configuración de nodo
          • Únase a una red
          • Nodo de sincronización
          • Validador
          • Actualizaciones
          • Solución de problemas
          • Programa de delegación
            • objetivos del programa
            • Parámetros de evaluación
            • Solicitud
      • Movement
        • Desarrolladores
          • Inicio rápido
          • Configuración
            • Usando contenedores
            • Usando el instalador
          • Tutoriales
            • Desplegar
              • Módulo Aptos
              • Módulo Sui
              • Contratos EVM
                • Implementación de contratos de solidez en movimiento utilizando Foundry y Fractal
                • Implementación de contratos de solidez en M1 usando Hardhat y Fractal
                • Implementación de contratos inteligentes de Solidity en M1 utilizando el tiempo de ejecución Fractal
            • Ejecute MoveVM
              • Ejecutando M1 usted mismo
            • Construir dApp
              • Aptos Move dApp
              • Aplicación Sui Move
              • DApp de solidity
            • Interoperar
              • AptosVM<>MEVM
          • Herramientas de desarrollo
            • Movement CLI
              • Movement aptos
                • cuenta
                  • crear
                  • crear-cuenta-de-recursos
                    • derivar-dirección-de-cuenta-de-recursos
                  • fondo-con-grifo
                  • lista
                  • dirección de búsqueda
                  • rotar llave
                  • transferir
                • configuración
                  • generar-compleciones-de-shell
                  • configurar-global-config
                  • show-global-config
                  • mostrar-perfiles
                • génesis
                  • generar-admin-escritura-conjunto
                  • generar-génesis
                  • obtener direcciones de grupo
                  • generar-claves
                  • generar-plantilla-de-diseño
                  • configuración-git
                  • configuración-del-validador-de-conjuntos
                • gobernancia
                  • proponer
                  • votar
                  • propuesta de show
                  • lista-propuestas
                  • verificar-propuesta
                  • ejecutar propuesta
                  • generar-propuesta-de-actualización
                  • aprobar-ejecución-hash
                • información
                • init
                • llave
                  • generar
                  • extraer-peer
                • mover
                  • construir-publicar-carga útil
                  • limpio
                  • compilar
                  • script de compilación
                  • cobertura
                    • resumen
                    • fuente
                    • código de bytes
                  • crear-cuenta-de-recursos-y-publicar-paquete
                  • desmontar
                  • documento
                  • descargar
                  • init
                  • list
                  • probar
                  • publicar
                  • correr
                  • ejecutar guión
                  • prueba
                  • prueba transaccional
                  • verificar-paquete
                  • vista
                • multifirma
                  • aprobar
                  • crear
                  • crear-transacción
                  • ejecutar
                  • ejecutar-rechazar
                  • ejecutar con carga útil
                  • rechazar
                  • verificar-propuesta
                • nodo
                  • analizar-validador-rendimiento
                  • arranque-db
                  • verificar-conectividad-de-red
                  • conseguir-participación-pool
                  • inicializar-validador
                  • conjunto de validadores de unión
                  • conjunto de validadores de licencia
                  • mostrar-información-de-época
                  • mostrar-validador-config
                  • mostrar-conjunto-validador
                  • mostrar-validador-participación
                  • ejecutar-testnet-local
                  • actualización-clave-de-consenso
                  • actualizar-validador-direcciones-de-red
                • apostar
                  • agregar apuesta
                  • crear-contrato-de-participación
                  • distribuir-monedas-adquiridas
                  • aumentar-bloqueo
                  • inicializar-propietario de la participación
                  • solicitud-comisión
                  • establecer-votante-delegado
                  • operador de conjunto
                  • desbloquear-apuesta
                  • desbloquear-monedas-adquiridas
                  • retirar-apuesta
                • actualizar
              • movement sui
                • comenzar
                • génesis
                • ceremonia-genesis
                  • init
                  • estado de validación
                  • agregar-validador
                  • validadores de lista
                  • punto de control de compilación sin firmar
                  • examinar-punto-de-control-génesis
                  • verificar y firmar
                  • finalizar
                • herramienta clave
                  • convertir
                  • decodificar-tx-bytes
                  • decodificar-multi-sig
                  • generar
                  • importar
                  • lista
                  • par de claves de carga
                  • dirección multifirma
                  • multi-sig-combinar-sig-parcial
                  • herencia-sig-parcial-combinada-multi-sig
                  • espectáculo
                  • firmar
                  • señal-kms
                  • deshacer
                  • zk-login-firmar-y-ejecutar-tx
                  • zk-login-ingresar-token
                  • zk-login-sig-verificar
                  • zk-login-signo-inseguro-mensaje-personal
                • consola
                • cliente
                  • dirección activa
                  • entorno-activo
                  • direcciones
                  • llamar
                  • identificador de cadena
                  • campo dinámico
                  • env
                  • ejecutar-tx firmado
                  • gas
                  • fusionar moneda
                  • nueva direccion
                  • nuevo-ambiente
                  • objeto
                  • objetos
                  • pagar
                  • pago todo-sui
                  • pay-sui
                  • publicar
                  • moneda dividida
                  • cambiar
                  • bloque tx
                  • transferir
                  • transferencia-sui
                  • mejora
                  • verificar-bytecode-metro
                  • verificar-fuente
                  • transacción-repetición
                  • lote de repetición
                  • punto de control de repetición
                • validador
                  • hacer-información-validador
                  • convertirse en candidato
                  • comité conjunto
                  • comité de licencia
                  • metadatos de visualización
                  • actualizar-metadatos
                    • nombre
                    • descripción
                    • URL de la imagen
                    • URL del proyecto
                    • dirección de red
                    • dirección primaria
                    • dirección-trabajador
                    • dirección-p2p
                    • clave-pub-de-red
                    • clave-pub-trabajador
                    • protocolo-pub-clave
                  • actualizar-precio-de-gas
                  • validador de informes
                  • serializar-carga útil-pop
                  • mostrar-actualización-del-precio-del-gas-raw-txn
                • move
                  • construir
                  • cobertura
                    • resumen
                    • fuente
                    • código de bytes
                  • desmontar
                  • nuevo
                  • probar
                  • prueba
                • simulacro de incendio
                  • rotación de metadatos
              • movement ctl
              • movement manage
            • fractales
              • marco evm
          • Desarrolladores Aptos
            • Configurar la CLI de Aptos
            • Usando la CLI de Aptos
          • Desarrolladores Sui
            • Configurar Sui CLI
            • Usando Sui CLI
          • Preguntas más frecuentes
        • Ecosistema
          • Wallets
          • Tokens
          • Faucet
          • Move idioma
            • Módulos y scripts
            • Tipos primitivos
              • Enteros
              • booleano
              • DIRECCIÓN
              • Vector
              • Firmante
              • Referencias
              • Tuplas y unidad
          • Recursos de aprendizaje
          • Techpedia
            • Paralelización
            • Mover recursos
            • SDK de movement
      • Initia
        • ACERCA DE
          • Bienvenido a Inicia
          • Arquitectura Omnitia
            • Inicia (Capa 1)
            • Minitia (Capa 2)
          • Ciclo de vida de la transacción
          • Liquidez y apuestas consagradas
            • IniciaDEX
          • Programa de intereses adquiridos
        • CONSTRUIR SOBRE LA INICIATIVA
          • iniciado
          • inicia.js
          • Creando cuenta
          • Tutoriales específicos de VM
            • MoverVM
              • Implementación de módulos de movimiento
              • Creando moneda de movimiento
              • Envío de moneda de movimiento
              • Creando movimiento NFT
              • Módulos relacionados con el replanteo
              • Interactuar con Oracle en MoveVM
              • Mover ganchos IBC
            • WASMVM
              • Implementación del contrato CosmWasm
              • Interactuando con Oracle en WasmVM
              • Ganchos Wasm IBC
              • Fábrica de fichas
            • EVM
              • Implementación del contrato de solidez
              • Crear un token ERC-20 personalizado
              • Consultar estados del cosmos
              • Ejecutando mensajes de Cosmos
              • Conversión de direcciones entre EVM y Cosmos
              • Conversión entre direcciones Denom y ERC-20
              • Interactuar con Oracle en EVM
              • Ganchos EVM IBC
              • Ethereum JSON-RPC
          • Tutoriales generales
            • Oráculo: Furtivo
            • Mensajes entre cadenas
            • Saltar API
            • Miniswap
              • Interactuando con Minitswap
            • Conversión entre nombres de usuario y direcciones
            • Usando el Explorador local de Initia
            • Interactuando con InitiaDEX
            • Usando el widget de billetera Initia
        • IMPLEMENTAR MINITIA
          • Empezando
            • Implementación de su propia Minitia (Capa 2)
          • Configuración
          • Implementación de una Minitia independiente
          • Implementación completa de Minitia
            • Dirigiendo la Minitia
            • Pila de OPinit
              • Módulo OPinit: OPhost y OPchild
              • Configurar robots OPinit
                • Ejecutor del puente
                • Remitente de salida
                • Desafiador
                • Envío por lotes
                  • Envío de lotes a Inicia L1
                  • Envío de lotes a Celestia
            • Relé Hermes (IBC)
            • Habilitando oráculos
          • Retroceder
          • Agregar tokens a Initia Wallet
          • Personalizando Minitia
        • EJECUTAR EL NODO DE INICIO
          • Ejecutando el nodo de inicio
          • Arrancar un nodo de inicio
          • Conéctese a la red Inicial
          • Oráculo
          • Automatización de actualizaciones de software con Cosmovisor
          • Convertirse en un validador
        • RECURSOS
          • Registro de Iniciación
          • Información de la cadena Testnet
          • Parámetros de cadena
          • Documentación de la API
          • Documentos API (MiniMove)
          • Documentos API (MiniWasm)
          • Documentos API (MiniEVM)
      • Internet Computer
        • ¡Hola, mundo!
        • Descripción general del ICP
Powered by GitBook
On this page
  • Introducción
  • Instalación de Prometheus
  • Instalación de Node exporter
  • Configuración del Proceso de Grafana en el sistema
  1. Recursos
  2. Nodos validadores

Guía de instalación Prometheus y Grafana para un Validador

Guia de instalación del monitoreo para un Validador

PreviousInstalación de AutoCompoundNextDesarrollo

Last updated 2 years ago

Introducción

Los nodos validadores miden el tiempo de disponibilidad u operación (en inglés uptime) como parámetro de calidad, para mantener un tiempo de disponibilidad entre valores de 99,9% y 100% es muy importante tener un mecanismos que nos permita conocer el estado del sistema constantemente, dado que en algún momento puede ocurrir algún problema en los servicios o en el hardware, un sistema de monitoreo y alertas nos ayuda a identificar oportunamente y tomar acción para mitigar los largos periodos de inactividad en los nodos validadores.

Para ello nosotros usamos y recomendamos Prometheus como sistema de recopilación y almacenamiento de métricas, Node Exporter como exportador de datos a monitorear en cada uno de los servidores y Grafana como interfaz gráfica y de fácil administración para el monitoreo y las alertas.

Prometheus

Prometheus es un software libre enfocado en la recopilación de métricas, monitoreo de eventos y alertas cuando sea necesario, Está desarrollado en Go y está licenciado bajo Apache también se dispone de su código fuente en su y es un proyecto graduado de Cloud la Native Computing Foundation junto a Kubernetes. Si quiere conocer más sobre Prometheus puede ir a su página oficial .

Node exporter

Es el encargado de enviar los datos a prometheus referente al hardware y métricas del sistema operativo, este software también está desarrollado en go, si quiere conocer más acerca de node exporter puede revisar su información y código fuente que también está publicado en . Para descargarlo puede ir al link de descarga oficial .

Grafana

Grafana es una aplicación web desarrollada en lenguaje Go y cuenta con licencia de apache 2, esta aplicación permite la visualización de métricas en cuadros y paneles, esta aplicación admite varias fuentes de datos y recopiladores de métricas como lo pueden ser Graphite y Prometheus. Si quiere conocer más acerca de Grafana puede ir a su página oficial .

Arquitectura

Para nuestro caso hemos dispuesto de una máquina o servidor dedicado solamente a monitorear los otros servidores, en dicha máquina tenemos comunicación de manera privada hacia los diferentes validadores ó sistemas que deseamos monitorear. El sistema está basado en Gnu/Linux y lo tenemos parametrizado de manera estándar en este momento.

Cada nodo validador tiene trabajando el software llamado Node Exporter, este software se encarga de exportar los datos necesarios o los que necesitemos para el monitoreo, estos datos son recopilados por prometheus el cual está en el servidor dedicado al monitoreo y este se encarga de darles formato para que podamos visualizarlos y entenderlos. Grafana por su parte tiene la capacidad de tomar los datos que recopila prometheus y mostrarlos vía web de una forma agradable y más entendible a la vista de un usuario.

Topología

A continuación vamos a describir el proceso de instalación de las diferentes herramientas:

Instalación de Prometheus

Usuario y grupo de monitoreo

Se crea el usuario y el grupo de monitoreo, también se crean los directorios para prometheus

groupadd --system monitoreo
useradd -s /bin/false -r -g monitoreo monitoreo

mkdir /etc/prometheus
mkdir /var/lib/prometheus

Descargar Prometheus:

mkdir Downloads/prometheus -p 
cd Downloads/prometheus
#Descargar la última versión
wget 
https://github.com/prometheus/prometheus/releases/download/v2.42.0/prometheus-2.42.0.linux-amd64.tar.gz
tar -xvf prometheus-2.42.0.linux-amd64.tar.gz

Se procede a instalar

cd prometheus
install prometheus /usr/local/bin/
install promtool /usr/local/bin/
mv consoles /etc/prometheus/
mv console_libraries /etc/prometheus/
mv prometheus.yml /etc/prometheus/

Configuración de Prometheus

Ingresar a la ubicación del archivo de configuración de prometheus

cd /etc/prometheus
#Copia de seguridad del archivo de configuración para modificarlo
mv prometheus.yml prometheus.yml.bak
#creamos y editamos el archivo de configuración nuevo
nano prometheus.yml
global:
  scrape_interval: 15s

scrape_configs:
  - job_name: 'prometheus'
    scrape_interval: 5s
    static_configs:
      - targets: ['localhost:9090']

  - job_name: 'monitoreo'
    scrape_interval: 5s
    static_configs:
      - targets: ['localhost:9100']

Se establecen los permisos en los archivos y binarios de instalación al usuario y grupo de monitoreo.

chown monitoreo:monitoreo /usr/local/bin/prometheus
chown monitoreo:monitoreo /usr/local/bin/promtool
chown monitoreo:monitoreo /var/lib/prometheus -R
chown monitoreo:monitoreo /etc/prometheus -R
chmod -R 775 /etc/prometheus/ /var/lib/prometheus/

Configuración del Proceso de Prometheus en el sistema

Procedemos a crear el proceso para permitir que se ejecute en segundo plano.

nano /etc/systemd/system/prometheus.service
#Editamos el archivo de esta manera
[Unit]
  Description=Prometheus Monitor
  Wants=network-online.target
  After=network-online.target

[Service]
  User=monitoreo
  Group=monitoreo
  Type=simple
  ExecStart=/usr/local/bin/prometheus \
  --config.file /etc/prometheus/prometheus.yml \
  --storage.tsdb.path /var/lib/prometheus/ \
  --web.console.templates=/etc/prometheus/consoles \
  --web.console.libraries=/etc/prometheus/console_libraries

[Install]
  WantedBy=multi-user.target
  SyslogIdentifier=prometheus
  Restart=always

Se fijan los siguientes permisos al usuario monitoreo sobre el binario de prometheus

chown monitoreo:monitoreo /var/lib/prometheus -R
chmod 775 /var/lib/prometheus -R

Habilitamos e iniciamos el servicio de prometheus

systemctl daemon-reload
systemctl enable prometheus
systemctl start prometheus

#Se verifica que el demonio está corriendo correctamente 
systemctl status prometheus

Ahora se podrá ver la interfaz web de prometheus en cualquier navegador web, se pone en la barra de búsqueda la ip y el puerto de prometheus para este caso localhost:9090

Instalación de Node exporter

Descarga e instalar node_exporter

Descarga la última versión desde la página oficial, esta puede estar obsoleta al momento de leer esta guía

mkdir Downloads/exporter -p
cd Downloads/exporter
wget https://github.com/prometheus/node_exporter/releases/download/v1.5.0/node_exporter-1.5.0.linux-amd64.tar.gz
#Descomprimimos el archivo descargado
tar -xvzf node_exporter-1.5.0.linux-amd64.tar.gzz
cd cd node_exporter-1.5.0.linux-amd64/

Se mueve y se copia el binario dentro de las carpetas del sistema y se le otorgan permisos al usuario y grupo de monitoreo

mv node_exporter /usr/local/bin/
chown monitor:monitor /usr/local/bin/node_exporter
chmod 775 /usr/local/bin/node_exporter

Configuración del Proceso de Node Exporter en el sistema

Procedemos a crear el proceso para permitir que se ejecute en segundo plano.

nano /etc/systemd/system/exporter.service
#Lo editamos de la siguiente manera
[Unit]
Description=Node exporter
After=network-online.target

[Service]
User=monitoreo
Type=simple
ExecStart=/usr/local/bin/node_exporter

[Install]
WantedBy=multi-user.target
Restart=always

Habilitamos e iniciamos el servicio de Node Exporter

systemctl daemon-reload
systemctl enable exporter
systemctl start exporter
#Se verifica que el demonio está corriendo correctamente 
systemctl status exporter

Se puede verificar la información exportada en cualquier navegador web colocando en la barra de búsqueda la ip del servidor con el puerto dedicado para Node Exporter en este caso usamos localhost:9100 y se obtiene lo siguiente:

Instalación de Grafana

Grafana es nuestra parte visual y de administración de dashboards para la información recolectada por prometheus, acá también se podrán configurar las alertas para que lleguen a nuestro email, telegram, line, discord entre otras muchas posibilidades.

Descargar e instalar grafana.

mkdir Downloads/grafana -p
cd grafana
wget https://dl.grafana.com/enterprise/release/grafana-enterprise_9.3.6_amd64.deb
#Se procede con la instalación a partir del binario
sudo dpkg -i grafana_9.3.6_amd64.deb

Configuración del Proceso de Grafana en el sistema

Grafana ya viene con un proceso por defecto, lo único que tendremos que hacer es iniciarlo.

systemctl enable grafana-server
systemctl start grafana-server
systemctl status grafana-server

Se puede verificar si está activo revisando desde cualquier navegador web y colocando en la barra de búsqueda la ip del servidor con el puerto dedicado para Grafana en este caso usamos localhost:3000 y se obtiene lo siguiente:

Para ingresar por defecto el usuario de grafana es admin y la contraseña también es admin, una vez haya ingresado puede modificar sus credenciales de acceso.

Importar métricas de Prometheus

Vamos a la sección Import para traer un panel por defecto, si conoce del tema puede poner su propio panel favorito si no tiene panel favorito puede usar uno de los dashboard más conocidos que es el 11074 de la siguiente manera:

Cuando le damos clic al boton “Load” nos saldrá la siguiente interfaz donde le asignamos el nombre, el folder donde queremos que se almacene el dashboard, el ID del Dashboard y por último elegiremos Prometheus para que automáticamente lo detecte.

Después damos clic sobre el boton “Import” y aparecerá un dashboard similar a este.

Realizado por:

Mauricio Gil - maurog@decry.io

fabian - vfabian@decry.io

Fecha: Marzo del 2023

Posterior a esto se descarga la última versión desde la página oficial .

En el contenido de configuración puede dejarlo por defecto, el primer job_name es el correspondiente a prometheus que se aloja por defecto en el puerto 9090 y el otro es el que estaría exportando los datos de métricas desde , que es lo que veremos después de terminar prometheus.

Interfaz web inicial de prometheus

Para que prometheus pueda obtener las métricas de otros servidores o del servidor mismo donde está instalado se debe usar el software Node Exporter, esta se puede descargar también de la página oficial .

Salida en el navegador de Node Exporter

Para descargar grafana, vamos a la página oficial y descargamos la última versión, en este caso es la v9.3.6 pero para el momento que está mirando esto, puede que ya esté obsoleta, por favor verifique la última versión en la página de descarga oficial .

Interfaz de ingreso web a Grafana
Importar el Dashboard
Dashboard importado

Puede probar distintos dashboards que existen por defecto, los puede buscar en la o puede crear uno personalizado.

👽
💻
aquí
node exporter
aquí
aquí
documentación de grafana
github
aquí
github
aquí
aquí