Workshop: Deploy descomplicado de aplicações em VPS 🚀

Monitorando Aplicações PHP com Prometheus

Publicado em 16/01/2017

Atualizado em 03/06/2024

Essa semana nosso time de desenvolvimento teve o desafio de buscar ferramentas para monitorar aplicações web, tendo uma visão completa tanto do host quanto dos containers. Além disso, centralizar a visualização de alguns dados da aplicação.

Depois de algumas pesquisas, encontrei esse repositório que me chamou bastante atenção: https://github.com/stefanprodan/dockprom. Trata-se de um conjunto de serviços para monitoramento e alerta!

Tudo que precisávamos!

Serviços Utilizados

Prometheus?—?Repositório e Métricas
Grafana?—?Visualização
AlertManager?—?Gerenciador de Alertas
NodeExporter?—?Coleta de dados do Host
cAdvisor?—?Coleta de dados dos Containers

Em poucos minutos, é possível visualizar os dados do seu host como estes abaixo. Lembrando que o projeto já inclui alguns dashboards bem completos, basta importá-los ao Grafana.

prometeus

Centralização de Informação

A melhor parte é que não ficamos presos a um único host, podendo distribuir os containers e ainda centralizar a visualização dos dados.

O Prometheus é o encarregado dessa mágica. Com ele é possível configurar Scrapers que ficarão observando a sua aplicação e coletando as métricas automaticamente.

scrape_configs:
  - job_name:       'example-random'

    # Override the global default and scrape targets from this job every 5 seconds.
    scrape_interval: 5s

    static_configs:
      - targets: ['localhost:8080', 'localhost:8081']
        labels:
          group: 'production'

      - targets: ['localhost:8082']
        labels:
          group: 'canary'

Enviando dados da Aplicação

Para que o Prometheus consiga capturar corretamente os dados da sua aplicação é necessário que a saída seja formatada de uma maneira específica, e para isso temos diversos clients. No nosso caso, vou mostrar um pouco do Client PHP

Abaixo, nós adicionamos algumas métricas sobre a aplicação.

$registry = \Prometheus\CollectorRegistry::getDefault();

$counter = $registry->getOrRegisterCounter('test', 'some_counter', 'it increases', ['type']);
$counter->incBy(3, ['blue']);

$gauge = $registry->getOrRegisterGauge('test', 'some_gauge', 'it sets', ['type']);
$gauge->set(2.5, ['blue']);

$histogram = $registry->getOrRegisterHistogram('test', 'some_histogram', 'it observes', ['type'], [0.1, 1, 2, 3.5, 4, 5, 6, 7, 8, 9]);
$histogram->observe(3.5, ['blue']);

E logo após, expomos esses dados para a coleta do Scraper

$registry = \Prometheus\CollectorRegistry::getDefault();
$registry = CollectorRegistry::getDefault();

$renderer = new RenderTextFormat();
$result = $renderer->render($registry->getMetricFamilySamples());

header('Content-type: ' . RenderTextFormat::MIME_TYPE);
echo $result;

Exporters

Para finalizar, podemos adicionar exporters para quase todos os tipos de serviços que utilizamos, desde dados de deploy do Jenkins, como dados de filas do RabbitMQ.

Basta conferir essa lista de exporters para entender as infinitas possibilidades de monitoramento dessa ferramenta.

Nós, da Kinghost, ficamos bem empolgados com esse potencial, e espero que seja útil para outros Devs também.

O AlertManager merece um capitulo só para ele, abordando configurações de saída e querys de alertas, então, aguardem o próximo artigo!

O que você achou deste conteúdo?

O que você achou deste conteúdo?

Daniel
Daniel Archer
Focado em performance e boas práticas de programação, certificado ZEND ZCPE 5.5.
Daniel
Daniel Archer
Focado em performance e boas práticas de programação, certificado ZEND ZCPE 5.5.

Compartilhe esse conteúdo com alguém que possa gostar também

Receba todo mês conteúdos
incríveis como esses para
seguir evoluindo

Conteúdos relacionados

A conteinerização é uma forma de empacotar aplicações junto com todas as suas dependências em unidades isoladas chamadas containers. Esses containers podem ser executados de maneira consistente em diferentes ambientes computacionais, desde o computador de um desenvolvedor até servidores em nuvem. A complexidade do deploy de aplicações aumentou bastante com a evolução da arquitetura de...
Ferramentas anti-DDoS são fundamentais porque analisam padrões de comportamento do tráfego, separando acessos legítimos de tentativas automatizadas de sobrecarga. Quando um comportamento anômalo é detectado, o sistema aplica medidas de mitigação, como bloqueio de IPs suspeitos ou redirecionamento de tráfego. Plataformas digitais, e-commerces, aplicações SaaS e sites corporativos dependem de acesso contínuo para manter operações,...
Diferentemente de um servidor web tradicional, que se concentra na entrega de conteúdo estático, o servidor de aplicação executa regras complexas, controla transações e gerencia componentes que sustentam sistemas corporativos. Um dos grandes desafios à medida que o seu negócio cresce é adaptar as suas ferramentas à lógica da sua operação. O servidor de aplicação,...
Saber o que é HTTPS significa entender que vai muito além de um protocolo de segurança, mas sim um recurso essencial para proteger a credibilidade do seu negócio e até mesmo a performance das suas páginas. Mais do que pensar no layout das suas páginas, nos produtos que você vai oferecer ou até mesmo o...

Mensagens para você