Skip to main content

Useful scripts to parse and visualize MongoDB log files, launch test environments, and reproduce issues.

Project description

PyPI version PyPI pyversions PyPI license

mtools is a collection of helper scripts to parse, filter, and visualize MongoDB log files (mongod, mongos). mtools also includes mlaunch, a utility to quickly set up complex MongoDB test environments on a local machine, and mtransfer, a tool for transferring databases between MongoDB instances.

mtools box

What’s in the box?

The following tools are in the mtools collection:

mlogfilter

slices log files by time, merges log files, filters slow queries, finds table scans, shortens log lines, filters by other attributes, convert to JSON

mloginfo

returns info about log file, like start and end time, version, binary, special sections like restarts, connections, distinct view

mplotqueries

visualize log files with different types of plots (requires matplotlib)

mlaunch

a script to quickly spin up local test environments, including replica sets and sharded systems (requires pymongo)

mtransfer

an experimental script to transfer databases between MongoDB instances by copying WiredTiger data files (requires pymongo and wiredtiger)

For more information, see the mtools documentation.

Requirements and Installation Instructions

The mtools collection is written in Python, and most of the tools only use the standard packages shipped with Python. The tools are currently tested with Python 3.7, 3.8, 3.9, and 3.10.

Some of the tools have additional dependencies, which are listed under the specific tool’s section. See the installation instructions for more information.

The mtools suite is only tested with actively supported (non End-of-Life) versions of the MongoDB server. As of October 2022, that includes MongoDB 4.2 or newer.

NOTE: logv2 format (MongoDB 4.4+) is not fully supported yet.

Recent Changes

See Changes to mtools for a list of changes from previous versions of mtools.

Contribute to mtools

If you’d like to contribute to mtools, please read the contributor page for instructions.

Disclaimer

This software is not supported by MongoDB, Inc. under any of their commercial support subscriptions or otherwise. Any usage of mtools is at your own risk. Bug reports, feature requests and questions can be posted in the Issues section on GitHub.

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

mtools-1.7.2.tar.gz (2.9 MB view hashes)

Uploaded source

Built Distribution

mtools-1.7.2-py3-none-any.whl (2.1 MB view hashes)

Uploaded py3

Supported by

AWS AWS Cloud computing Datadog Datadog Monitoring Facebook / Instagram Facebook / Instagram PSF Sponsor Fastly Fastly CDN Google Google Object Storage and Download Analytics Huawei Huawei PSF Sponsor Microsoft Microsoft PSF Sponsor NVIDIA NVIDIA PSF Sponsor Pingdom Pingdom Monitoring Salesforce Salesforce PSF Sponsor Sentry Sentry Error logging StatusPage StatusPage Status page