keyhole

command module
v2.4.2-rc1+incompatible Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 27, 2020 License: MIT Imports: 16 Imported by: 1

README

Keyhole - MongoDB Performance Analytic

Keyhole is a performance analytics tool, written in GO (Golang), to collect stats from MongoDB instances and to measure performance of a MongoDB cluster. Moreover, keyhole can read MongoDB full-time diagnostic data (FTDC) data and is integrated with Grafana's Simple JSON plugin seamlessly. Golang was chosen to eliminate the needs to install an interpreter or 3pp modules.

With Keyhole, experienced users should be able to spot performance issues and to determine whether upgrades are needed quickly from a few minutes of testing and analyzing the results. Keyhole supports TLS/SSL connections.

Several features are available, and they are

  • Write Throughputs Test measures the MongoDB performance by writing documents at a high rate to a MongoDB cluster.
  • Load test extends the Write throughputs test by issuing different ops against a MongoDB cluster. Stats analytic is also provided
    • Memory: resident, virtual, and page faults
    • Executor and ops
    • Latency: read, write, and command
    • Metrics: index keys examined, collection scan, in-memory sort, and ops
    • WiredTiger analytic
  • Customized load test with a sample document. Uses can load test using their own document format (see LOADTEST.md for details).
  • Cluster Info to display information of a cluster including stats to help determine physical memory size.
  • Display all indexes and their usages
  • Seed data for demo and educational purposes as a trainer.
  • Display average ops time and query patterns by parsing logs.
  • Display indexes scores of a query shape

Use Cases

Refer to wiki for user's guide.

Usages

Build

You need go installed and use dep to pull down dependencies.

./build.sh
Usage
keyhole --help
Unit Tests
./test.sh load
Atlas TLS/SSL Mode

An example connecting to Atlas

keyhole --info "mongodb+srv://user:secret@cluster0-v7due.gcp.mongodb.net/test"
TLS/SSL Mode
keyhole --info --sslCAFile /etc/ssl/certs/ca.pem --sslPEMKeyFile /etc/ssl/certs/client.pem "mongodb://user:password@localhost/keyhole?authSource=admin&ssl=true"

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
sim

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL