Skip to content

dv-morais/Rocket.Chat.Metrics

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

35 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Rocket.Chat.Metrics

This repository contains a basic Monitoring setup Rocket.Chat setups, based on Grafana and Prometheus. It currently shows and visualizes the following application metrics/information:

  • General totals (users online/away, DDP users, diffs based on time range)
  • Metrics (requests and total size per instance)
  • NodeJS (active handles, requests, event loop lag, heap used, per instance heap, garbage collector)
  • DDP rate limiter (by method, by type, by userId, by connectionId)
  • Rocket.Chat Data (messages sent, total sent, user presence, users & sessions, Oplog, push queue, Meteor facts, total users, total rooms, notification per minute per notification type)
  • Meteor (methods total time, methods time, method calls per minute)
  • Subscriptions (subscription total time, subscription time, subscription calls per minute)
  • Callbacks & Hooks (callbacks total time, callbacks time, callback calls per minute, hooks total time, hooks time, hook calls per minute)
  • REST API (REST total time, REST time, REST calls per minute)

Preparation

  1. Make sure you meet all requirements.

  2. Clone this repository:

    git clone https://github.com/RocketChat/Rocket.Chat.Metrics /opt/docker/Rocket.Chat.Metrics
    cd /opt/docker/Rocket.Chat.Metrics
  3. Adjust the default Prometheus configuration according the usage information below (either for Docker-based or static Rocket.Chat setups).

  4. Create and start up containers using docker-compose. Make sure to include both compose files:

    docker-compose up -d
    
  5. Access your Grafana instance via http://${HOST_IP}:3000.

    Note: If you host this metrics setup on the same system as your Rocket.Chat server, you might run into port collisions when trying to bind Grafana to port 3000 as it is already used by Rocket.Chat. Feel free to adjust it in the docker-compose.yml as needed.

Initial configuration

Rocket.Chat

To allow Prometheus to scrape data from Rocket.Chat you need to make sure to enable the exporter within the Rocket.Chat admin UI → Logs → Prometheus:

Prometheus

Monitor a single Rocket.Chat server

To monitor one or multiple static Rocket.Chat systems ("static" in terms of the Prometheus metrics endpoint doesn't change and is always available under the same address) you just have to add each of your Rocket.Chat hostnames in the ./config/prometheus/prometheus.yml file like this:

- job_name: rocketchat_static
  static_configs:
  - targets:
    - rocketchat1.company.com:9458
    - rocketchat2.company.com:9458

Where rocketchat1.company.com and rocketchat2.company.com are reachable endpoints from within the Prometheus container.

Monitor a multi-instance or Docker-based Rocket.Chat server/setup

In case you have a Docker-based setup that might scale additional application instances in and out on the fly, you can use Prometheus DNS discovery method. Please make sure that the Prometheus container is within the same Docker network as your Rocket.Chat application containers. Use a configuration like this:

- job_name: rocketchat_docker
  scrape_interval: 30s
  dns_sd_configs:
  - names: ["rocketchat"]
    type: A
    port: 9458

Make sure to update rocketchat with the container name of your Rocket.Chat application container.

Grafana

Using Grafana

As soon as the containers are up and running, you can access the Grafana UI via the configured port and select the autoprovisioned dashboard "Rocket.Chat Metrics".

By default Grafana uses admin/admin as login credentials.

Default credentials

Additional system and Docker monitoring dashboards (optional)

  • cadvisor
  • node-exporter

Troubleshooting

I do not want to access the Prometheus Web UI.

By default the port for Prometheus' Web UI is exposed for easier metric troubleshooting. To disable it simple remove the ports mapping in the prometheus section of the compose file:

    ports:
     - 9090:9090

How to increase the persistent storage/history of Prometheus to more than 12 weeks?

You can adjust this by setting the storage.tsdb.retention.time command argument in the Prometheus container. For example:

  prometheus:
    image: quay.io/prometheus/prometheus:v2.16.0
    restart: unless-stopped
    command:
      - --config.file=/etc/prometheus/prometheus.yml
      - '--storage.tsdb.retention.time=1y'
      - '--storage.tsdb.path=/prometheus'

Metrics in detail

To help reading and interpreting the graphs of this Grafana dashboard, you can find a document that explains most of our metrics and graphs that are included here:

📒 ./metrics.md

Contributing

  1. Fork it

  2. Create your feature branch:

    git checkout -b feature/my-new-feature
  3. Commit your changes:

    git commit -am 'Add some feature'
  4. Push to the branch:

    git push origin feature/my-new-feature
  5. Submit a pull request

Requirements / Dependencies

  • Up and running Rocket.Chat system
  • Docker

License

MIT

About

Monitoring setup for Rocket.Chat servers

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published