Skip to main content

Rocksdb's log analyzer

Project description

Rocksdb Tuning Advisor

Motivation

The performance of Rocksdb is contingent on its tuning. However, because of the complexity of its underlying technology and a large number of configurable parameters, a good configuration is sometimes hard to obtain. The aim of the python command-line tool, Rocksdb Advisor, is to automate the process of suggesting improvements in the configuration based on advice from Rocksdb experts.

Overview

Experts share their wisdom as rules comprising of conditions and suggestions in the INI format (refer rules.ini). Users provide the Rocksdb configuration that they want to improve upon (as the familiar Rocksdb OPTIONS file — example) and the path of the file which contains Rocksdb logs and statistics. The Advisor creates appropriate DataSource objects (for Rocksdb logs, options, statistics etc.) and provides them to the Rules Engine. The Rules uses rules from experts to parse data-sources and trigger appropriate rules. The Advisor's output gives information about which rules were triggered, why they were triggered and what each of them suggests. Each suggestion provided by a triggered rule advises some action on a Rocksdb configuration option, for example, increase CFOptions.write_buffer_size, set bloom_bits to 2 etc.

Usage

Prerequisites

The tool needs the following to run:

  • python3

Running the tool

An example command to run the tool:

cd rocksdb/tools/advisor
python3 -m advisor.rule_parser_example --rules_spec=advisor/rules.ini --rocksdb_options=test/input_files/OPTIONS-000005 --log_files_path_prefix=test/input_files/LOG-0 --stats_dump_period_sec=20

Command-line arguments

Most important amongst all the input that the Advisor needs, are the rules spec and starting Rocksdb configuration. The configuration is provided as the familiar Rocksdb Options file (refer example). The Rules spec is written in the INI format (more details in rules.ini).

In brief, a Rule is made of conditions and is triggered when all its constituent conditions are triggered. When triggered, a Rule suggests changes (increase/decrease/set to a suggested value) to certain Rocksdb options that aim to improve Rocksdb performance. Every Condition has a 'source' i.e. the data source that would be checked for triggering that condition. For example, a log Condition (with 'source=LOG') is triggered if a particular 'regex' is found in the Rocksdb LOG files. As of now the Rules Engine supports 3 types of Conditions (and consequently data-sources): LOG, OPTIONS, TIME_SERIES. The TIME_SERIES data can be sourced from the Rocksdb statistics or perf context.

For more information about the remaining command-line arguments, run:

cd rocksdb/tools/advisor
python3 -m advisor.rule_parser_example --help

Sample output

Here, a Rocksdb log-based rule has been triggered:

Rule: stall-too-many-memtables
LogCondition: stall-too-many-memtables regex: Stopping writes because we have \d+ immutable memtables \(waiting for flush\), max_write_buffer_number is set to \d+
Suggestion: inc-bg-flush option : DBOptions.max_background_flushes action : increase suggested_values : ['2']
Suggestion: inc-write-buffer option : CFOptions.max_write_buffer_number action : increase
scope: col_fam:
{'default'}

Running the tests

Tests for the code have been added to the test/ directory. For example, to run the unit tests for db_log_parser.py:

cd rocksdb/tools/advisor
python3 -m unittest -v test.test_db_log_parser

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

Adviser-Rocksdb-0.0.1.tar.gz (31.3 kB view details)

Uploaded Source

Built Distribution

Adviser_Rocksdb-0.0.1-py3-none-any.whl (41.0 kB view details)

Uploaded Python 3

File details

Details for the file Adviser-Rocksdb-0.0.1.tar.gz.

File metadata

  • Download URL: Adviser-Rocksdb-0.0.1.tar.gz
  • Upload date:
  • Size: 31.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.58.0 CPython/3.9.1

File hashes

Hashes for Adviser-Rocksdb-0.0.1.tar.gz
Algorithm Hash digest
SHA256 20c543ac1def9a9b03f82db72c0e5d949fc7942ee05dbfbbfba6991659e9f78b
MD5 917e139f5501b4473cd88beca8e2d2c5
BLAKE2b-256 e8c0f5e964f91cbeb565a6f5ff234ba86fca2e0aef41689519ceea7f51ec9760

See more details on using hashes here.

Provenance

File details

Details for the file Adviser_Rocksdb-0.0.1-py3-none-any.whl.

File metadata

  • Download URL: Adviser_Rocksdb-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 41.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.58.0 CPython/3.9.1

File hashes

Hashes for Adviser_Rocksdb-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c328d5df56a48b3f2285fc27233a7834c82c9e5dd1418ecb449fa01d67b420de
MD5 17454a731eba2a8c44ee088bf8ba6113
BLAKE2b-256 6aefcf55e88694180f063e698522c62c417a5638a41d728a1de0826fa592838d

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page