ScyllaDB University Live | Free Virtual Training Event
Learn more
ScyllaDB Documentation Logo Documentation
  • Server
  • Cloud
  • Tools
    • ScyllaDB Manager
    • ScyllaDB Monitoring Stack
    • ScyllaDB Operator
  • Drivers
    • CQL Drivers
    • DynamoDB Drivers
  • Resources
    • ScyllaDB University
    • Community Forum
    • Tutorials
Download
ScyllaDB Docs ScyllaDB Monitoring Download and Install Scylla Monitoring Stack Install Scylla Monitoring Stack

Caution

You're viewing documentation for a previous version of ScyllaDB Monitoring. Switch to the latest stable version.

Install Scylla Monitoring Stack¶

This document describes the setup of Scylla Monitoring Stack, based on Scylla Prometheus API

The Scylla Monitoring Stack needs to be installed on a dedicated server, external to the Scylla cluster. Make sure the Scylla Monitoring Stack server has access to the Scylla nodes so that it can pull the metrics over the Prometheus API.

For evaluation, you can run Scylla Monitoring Stack on any server (or laptop) that can handle three Docker instances at the same time. For production, see recommendations below.

Minimal Production System Recommendations¶

  • CPU - at least 2 physical cores/ 4vCPUs

  • Memory - 15GB+ DRAM and proportional to the number of cores.

  • Disk - persistent disk storage is proportional to the number of cores and Prometheus retention period (see the following section)

  • Network - 1GbE/10GbE preferred

Calculating Prometheus Minimal Disk Space requirement¶

Prometheus storage disk performance requirements: persistent block volume, for example an EC2 EBS volume

Prometheus storage disk volume requirement: proportional to the number of metrics it holds. The default retention period is 15 days, and the disk requirement is around 12MB per core per day, assuming the default scraping interval of 20s.

For example, when monitoring a 6 node Scylla cluster, each with 16 CPU cores (so a total of 96 cores), and using the default 15 days retention time, you will need minimal disk space for prometheus of

6 * 16 * 15 * 12MB ~ 16GB

To account for unexpected events, like replacing or adding nodes, we recommend allocating at least x2-3 space, in this case, ~50GB. Prometheus Storage disk does not have to be as fast as Scylla disk, and EC2 EBS, for example, is fast enough and provides HA out of the box.

Calculating Prometheus Minimal Memory Space requirement¶

Prometheus uses more memory when querying over a longer duration (e.g. looking at a dashboard on a week view would take more memory than on an hourly duration).

For Prometheus alone, you should have 60MB of memory per core in the cluster and it would use about 600MB of virtual memory per core. Because Prometheus is so memory demanding, it is a good idea to add swap, so queries with a longer duration would not crash the server.

# ScyllaDB Nodes# Cores Per ScyllaDB NodePrometheus Retention in DaysPrometheus RAMPrometheus Storage
00

Prerequisites¶

  • Follow the Installation Guide and install docker on the Scylla Monitoring Stack Server. This server can be the same server that is running Scylla Manager. Alternatively, you can Deploy Scylla Monitoring Stack Without Docker.

  • If you have Prometheus or Grafana installed, confirm that your version is supported by the Scylla Monitoring Stack version you want to install. Refer to the table below.

Scylla Monitoring Stack Compatibility Matrix¶

Scylla Monitoring Stack Version

Prometheus Version

Grafana Version

4.3

2.42.0

9.3.8

4.2

2.41.0

9.3.4

4.1

2.38.0

9.1.0

4.0

2.34.0

8.5.2

3.11

2.32.0

8.3.4

3.10

2.32.0

8.3.3

3.9.2

2.29.1

8.2.7

3.9

2.29.1

8.1.1

3.8

2.27.1

7.5.7

3.7

2.25.2

7.4.0

3.6

2.18.1

7.3.5

3.5

2.18.1

7.1.5

3.4

2.18.1

6.7.3

Docker Post Installation¶

Docker post installation guide can be found here

Note

Avoid running the container as root.

To avoid running docker as root, you should add the user you are going to use for Scylla Monitoring Stack to the Docker group.

  1. Create the Docker group.

sudo groupadd docker
  1. Add your user to the docker group. Log out and log in again. The new group will be active for this user on next login.

sudo usermod -aG docker $USER
  1. Start Docker by calling:

sudo systemctl enable docker

Install Scylla Monitoring Stack¶

Procedure

  1. Download and extract the latest Scylla Monitoring Stack binary;.

wget https://github.com/scylladb/scylla-monitoring/archive/scylla-monitoring-4.3.4.tar.gz
tar -xvf scylla-monitoring-4.3.4.tar.gz
cd scylla-monitoring-scylla-monitoring-4.3.4

As an alternative, you can clone and use the Git repository directly.

git clone https://github.com/scylladb/scylla-monitoring.git
cd scylla-monitoring
git checkout branch-4.3
  1. Start Docker service if needed

sudo systemctl restart docker

Configure Scylla Monitoring Stack¶

To monitor the cluster, Scylla Monitoring Stack (Specifically the Prometheus Server) needs to know the IP of all the nodes and the IP of the Scylla Manager Server (if you are using Scylla Manager).

This configuration can be done from files, or using the Consul api.

Scylla Manager 2.0 and higher supports the Consul API.

Configure Scylla nodes from files¶

  1. Create prometheus/scylla_servers.yml with the targets’ IPs (the servers you wish to monitor).

Note

It is important that the name listed in dc in the labels matches the datacenter names used by Scylla. Use the nodetool status command to validate the datacenter names used by Scylla.

For example:

- targets:
      - 172.17.0.2
      - 172.17.0.3
  labels:
      cluster: cluster1
      dc: dc1

Note

If you want to add your managed cluster to Scylla Monitoring Stack, add the IPs of the nodes as well as the cluster name you used when you added the cluster to Scylla Manager. It is important that the label cluster name and the cluster name in Scylla Manager match.

Using IPV6

To use IPv6 inside scylla_server.yml, add the IPv6 addresses with their square brackets and the port numbers.

For example:

- targets:
      - "[2600:1f18:26b1:3a00:fac8:118e:9199:67b9]:9180"
      - "[2600:1f18:26b1:3a00:fac8:118e:9199:67ba]:9180"
  labels:
      cluster: cluster1
      dc: dc1

Note

For IPv6 to work, both scylla Prometheus address and node_exporter’s –web.listen-address should be set to listen to an IPv6 address.

For general node information (disk, network, etc.) Scylla Monitoring Stack uses the node_exporter agent that runs on the same machine as Scylla does. By default, Prometheus will assume you have a node_exporter running on each machine. If this is not the case, for example if Scylla runs in a container and the node_exporter runs on the host, you can override the node_exporter targets configuration file by creating an additional file and passing it with the -n flag.

Note

By default, there is no need to create node_exporter_server.yml. Prometheus will use the same targets it uses for Scylla and will assume you have a node_exporter running on each Scylla server.

If needed, you can set your own target file instead of the default prometheus/scylla_servers.yml, using the -s for Scylla target files.

For example:

./start-all.sh -s my_scylla_server.yml -d prometheus_data

Mark the different Data Centers with Labels.

As can be seen in the examples, each target has its own set of labels to mark the cluster name and the data center (dc). You can add multiple targets in the same file for multiple clusters or multiple data centers.

You can use the genconfig.py script to generate the server file. For example:

./genconfig.py -d myconf -dc dc1:192.168.0.1,192.168.0.2 -dc dc2:192.168.0.3,192.168.0.4

This will generate a server file for four servers in two datacenters server 192.168.0.1 and 192.168.0.2 in dc1 and 192.168.0.3 and 192.168.0.4 in dc2.

OR

The genconfig.py script can also use nodetool status to generate the server file using the -NS flag.

nodetool status | ./genconfig.py -NS

2. Connect to Scylla Manager by creating prometheus/scylla_manager_servers.yml If you are using Scylla Manager, you should set its IP and port in this file.

You must add a scylla_manager_servers.yml file even if you are not using the manager. You can look at: prometheus/scylla_manager_servers.example.yml for an example.

For example if Scylla Manager host IP is 172.17.0.7 prometheus/scylla_manager_servers.yml would look like:

# List Scylla Manager end points

- targets:
  - 172.17.0.7:5090

Note that you do not need to add labels to the Scylla Manager targets.

Configure Scylla nodes using Scylla-Manager Consul API¶

Scylla Manager 2.0 has a Consul like API.

When using the manager as the configuration source, there is no need to set any of the files. Instead you should set the scylla-manager IP from the command line using the -L flag.

For example:

./start-all.sh -L 10.10.0.1

Note

If you are running Scylla-Manager on the same host as Scylla-Monitoring you should use -l flag so that the localhost address will be available from within the container.

Connecting Scylla-Monitoring to ScyllaDB¶

Scylla-Monitoring version 3.5 and higher can read tables from a ScyllaDB node using CQL. If your ScyllaDB cluster is user/password protected (See Scylla Authorization) you should assign a user and password for the Scylla-Grafana connection.

You can limit the user to read only, currently it only read table from the system keyspace.

You can set a user and password from a file or environment variables.

If the environment variables SCYLLA_USER and SCYLLA_PSSWD are set, they will be used.

To set the user and password from a file, edit grafana/datasource.scylla.yml. Uncomment the secureJsonData part and set the user and password.

Note

It is best to use a dedicated user and password with limited privileges.

Use an external directory for the Prometheus data directory¶

The -d flag, places the Prometheus data directory outside of its container and by doing that makes it persistent.

Note

Specifying an external directory is important for systems in production. Without it, every restart of the monitoring stack will result in metrics lost.

If the directory provided does not exist, the start-all.sh script will create it. Note that you should avoid running docker as root, the start-all.sh script will use the user permissions that runs it. This is important if you want to place the prometheus directory not under the user path but somewhere else, for example /prometheus-data.

In that case, you need to create the directory before calling start-all.sh and make sure it has the right permissions for the user running the command.

Add Additional Prometheus Targets¶

There are situations where you would like to monitor additional targets using the Prometheus server of the monitoring stack. For example, an agent that runs on a firewall server. The Prometheus server reads its targets from a file, this file is generated from a template when calling start-all.sh. To add your targets you would need to edit the template file before calling start-all.sh.

The template file is either prometheus/prometheus.yml.template if Prometheus reads the Scylla target from file, or prometheus/prometheus.consul.yml.template if Prometheus gets Scylla targets from the manager Consul API.

You can add a target at the end of the file, for example, the following example would read from a server with IP address 17.0.0.1 with a Prometheus port of 7000.

- job_name: 'myservice'
  # Override the global default and scrape targets from this job every 5 seconds.
  scrape_interval: 5s
  static_configs:
    - targets:
      - 17.0.0.1:7000

Start and Stop Scylla Monitoring Stack¶

Start¶

./start-all.sh -d prometheus_data

Stop¶

./kill-all.sh

Start a Specific Scylla Monitoring Stack Version¶

By default, start-all.sh will start with dashboards for the latest Scylla Open source version and the latest Scylla Manager version.

You can specify specific scylla version with the -v flag and Scylla Manager version with -M flag.

Multiple versions are supported. For example:

./start-all.sh -v 2020.1,2019.1 -M 2.1 -d prometheus-data

will load the dashboards for Scylla Enterprise versions 2020.1 and 2019.1 and the dashboard for Scylla Manager 2.1

Accessing the localhost¶

The Prometheus server runs inside a Docker container if it needs to reach a target on the local- host: either Scylla or Scylla-Manager, it needs to use the host network and not the Docker network. To do that run ./start-all.sh with the -l flag. For example:

./start-all.sh -l -d prometheus-data

Configure rsyslog on each Scylla node¶

generates metrics and alerts from logs. To get full functionality, you should use rsyslog. Scylla Monitoring Stack will act as an additional rsyslog server. Scylla Monitoring Stack collects Scylla logs using Loki and generates metrics and alerts based on these logs. To use this feature, you need to direct logs from each Scylla node to Loki. The recommended method to do this is by using rsyslog, where Scylla Monitoring Stack (Loki) acts as an additional rsyslog server. .. note:: Scylla can send logs to more than one log collection service.

Prerequisite, make sure rsyslog is installed and running. If rsyslog is not installed, follow the installation instruction.

Add scylla’s rsyslog configuration file. Add the file: /etc/rsyslog.d/scylla.conf.

If Scylla Monitoring Stack IP is 10.0.0.1, the file should look like

if $programname ==  'scylla' then @@10.0.0.1:1514;RSYSLOG_SyslogProtocol23Format

Restart rsyslog for the configuration to take effect.

systemctl restart rsyslog

View Grafana Dashboards¶

Point your browser to your-server-ip:3000 By default, Grafana authentication is disabled. To enable it and set a password for user admin use the -a option.

Was this page helpful?

PREVIOUS
Download and Install Scylla Monitoring Stack
NEXT
The start-all.sh Command
  • Create an issue
  • Edit this page

On this page

  • Install Scylla Monitoring Stack
    • Minimal Production System Recommendations
      • Calculating Prometheus Minimal Disk Space requirement
      • Calculating Prometheus Minimal Memory Space requirement
    • Prerequisites
    • Docker Post Installation
    • Install Scylla Monitoring Stack
    • Configure Scylla Monitoring Stack
      • Configure Scylla nodes from files
      • Configure Scylla nodes using Scylla-Manager Consul API
      • Connecting Scylla-Monitoring to ScyllaDB
      • Use an external directory for the Prometheus data directory
      • Add Additional Prometheus Targets
    • Start and Stop Scylla Monitoring Stack
      • Start
      • Stop
      • Start a Specific Scylla Monitoring Stack Version
      • Accessing the localhost
      • Configure rsyslog on each Scylla node
    • View Grafana Dashboards
ScyllaDB Monitoring
  • 4.3
    • 4.9
    • 4.8
    • 4.7
    • 4.6
    • 4.5
    • 4.4
    • 4.3
    • 4.2
    • 4.1
    • 4.0
    • 3.10
    • 3.9
    • 3.8
    • 3.7
    • 3.6
    • 3.5
  • Introduction
  • Download and Install
    • Install
    • The start-all.sh script
    • Deploy without Docker
    • Docker Compose
    • System Recommendations
    • Using Thanos
  • User Guide
    • CQL Optimization Dashboard
    • Advisor
      • Some queries use ALLOW FILTERING
      • Some queries use Consistency Level: ALL
      • Some queries use Consistency Level: ANY
      • Some queries are not token-aware
      • Some SELECT queries are non-paged
      • Some queries are non-prepared
      • Some queries use reverse order
      • Compaction takes lots of memory and CPU
      • Some operation failed due to unsatisfied consistency level
      • I/O Errors can indicate a node with a faulty disk
      • Some operations failed on the replica side
      • CQL queries are not balanced among shards
      • Prepared statements cache eviction
      • System Overload
  • Procedures
    • Datadog Integration
    • Alert Manager
      • Alerting
    • Adding and Modifying Dashboards
    • Upgrade Guides
      • Monitoring 3.x to 4.y
      • Monitoring 3.x to 3.y
      • Monitoring 2.x to 3.y
      • Monitoring 2.x to 2.y
      • Monitoring 1.x to 2.x
  • Upgrade
    • Monitoring 3.x to 4.y
    • Monitoring 3.x to 3.y
    • Monitoring 2.x to 3.y
    • Monitoring 2.x to 2.y
    • Monitoring 1.x to 2.x
  • Troubleshooting
    • Troubleshooting
    • Troubleshooting Guide for Scylla Manager and Scylla Monitor Integration
  • Reference
    • Support Matrix
    • Interfaces
  • GitHub Project
Docs Tutorials University Contact Us About Us
© 2025, ScyllaDB. All rights reserved. | Terms of Service | Privacy Policy | ScyllaDB, and ScyllaDB Cloud, are registered trademarks of ScyllaDB, Inc.
Last updated on 04 May 2025.
Powered by Sphinx 7.4.7 & ScyllaDB Theme 1.8.6