Metadata-Version: 2.1
Name: mtools-legacy
Version: 1.7.0.3
Summary: Useful scripts to parse and visualize MongoDB log files, launch test environments, and reproduce issues.
Home-page: https://github.com/rueckstiess/mtools
Author: Thomas Rueckstiess
Author-email: thomas@rueckstiess.net
License: Apache 2.0
Keywords: MongoDB logs testing
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Developers
Classifier: Topic :: Database
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Provides-Extra: all
Provides-Extra: mlaunch
Provides-Extra: mlogfilter
Provides-Extra: mloginfo
Provides-Extra: mplotqueries
Provides-Extra: mtransfer
License-File: LICENSE.md

======
mtools
======

|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.

.. figure:: https://raw.githubusercontent.com/rueckstiess/mtools/develop/mtools.png
   :alt: mtools box

What's in the box?
------------------

The following tools are in the mtools collection:

`mlogfilter <http://rueckstiess.github.io/mtools/mlogfilter.html>`__
   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 <http://rueckstiess.github.io/mtools/mloginfo.html>`__
   returns info about log file, like start and end time, version, binary,
   special sections like restarts, connections, distinct view

`mplotqueries <http://rueckstiess.github.io/mtools/mplotqueries.html>`__
   visualize log files with different types of plots (requires ``matplotlib``)

`mlaunch <http://rueckstiess.github.io/mtools/mlaunch.html>`__
   a script to quickly spin up local test environments, including replica sets
   and sharded systems (requires ``pymongo``)

`mtransfer <http://rueckstiess.github.io/mtools/mtransfer.html>`__
   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
<http://rueckstiess.github.io/mtools>`__.

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, and 3.9.

Some of the tools have additional dependencies, which are listed under the
specific tool's section. See the `installation instructions
<http://rueckstiess.github.io/mtools/install.html>`__ for more information.

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

Recent Changes
--------------

See `Changes to mtools <http://rueckstiess.github.io/mtools/changelog.html>`__
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
<http://rueckstiess.github.io/mtools/contributing.html>`__ for instructions.

Disclaimer
----------

This software is not supported by `MongoDB, Inc. <https://www.mongodb.com>`__
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
<https://github.com/rueckstiess/mtools/issues?state=open>`__ section on GitHub.

.. |PyPI version| image:: https://img.shields.io/pypi/v/mtools.svg
   :target: https://pypi.python.org/pypi/mtools/
.. |PyPI pyversions| image:: https://img.shields.io/pypi/pyversions/mtools.svg
   :target: https://pypi.python.org/pypi/mtools/
.. |PyPI license| image:: https://img.shields.io/pypi/l/mtools.svg
   :target: https://pypi.python.org/pypi/mtools/


