Metadata-Version: 2.1
Name: log4mongo
Version: 1.8.1
Summary: Python logging handler for MongoDB
Author-email: Oz N Tiram <oz.tiram@gmail.com>, Valdimir Goeje <vladimir.gorej@gmail.com>
Project-URL: homepage, https://github.com/log4mongo/log4mongo-python
Classifier: Development Status :: 5 - Production/Stable
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Intended Audience :: System Administrators
Classifier: Environment :: Console
Classifier: Environment :: Web Environment
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: BSD License
Classifier: Intended Audience :: Developers
Classifier: Operating System :: OS Independent
Classifier: Topic :: Software Development
Description-Content-Type: text/x-rst
License-File: LICENSE

log4mongo-python
================
log4mongo-python is mongo database handler for python logging, part of log4mongo.org project.
log4mongo-python is using pymongo driver - http://github.com/mongodb/mongo-python-driver


Requirements
------------

- python 3.6.2+
- pymongo 4.0+
- mongo database

For more information see *debian_requirements.txt* and *requirements.txt* files.

Configuration
-------------

Example handler python configuration:

.. code-block:: python

 import logging
 from log4mongo.handlers import MongoHandler

 logger = logging.getLogger('test')
 logger.addHandler(MongoHandler(host='localhost'))
 logger.warning('test')


Contextual information
----------------------

It is possible to decorate you document with contextual information. There are tow approaches.

**1.) approach**

.. code-block:: python

 import logging
 from log4mongo.handlers import MongoHandler

 handler = MongoHandler(host='localhost')
 logger = logging.getLogger('test')
 logger.addHandler(handler)
 logging.LoggerAdapter(logger, {'ip': '127.0.0.1'}).info('test')

**2.) approach**

.. code-block:: python

 import logging
 from log4mongo.handlers import MongoHandler

 handler = MongoHandler(host='localhost')
 logger = logging.getLogger('test')
 logger.addHandler(handler)
 logger.info('test', extra={'ip': '127.0.0.1'})


As you can see, second approach is more straightforward and there is no need to use LoggerAdapter.


Capped collections
------------------

Capped collections are fixed-size collections that support high-throughput operations that insert, retrieve,
and delete documents based on insertion order. Capped collections work in a way similar
to circular buffers: once a collection fills its allocated space, it makes room for new documents
by overwriting the oldest documents in the collection.

Before switching to capped collections, read this document please: http://docs.mongodb.org/manual/core/capped-collections/

This behaviour is disabled by default. You can enable this behaviour in constructor with *capped=True*:

.. code-block:: python

 import logging
 from log4mongo.handlers import MongoHandler

 handler = MongoHandler(host='localhost', capped=True)


Buffered handler
----------------

``BufferedMongoHandler`` is a subclass of ``MongoHandler`` allowing to buffer log messages
and write them all at once to the database. The goal is to avoid too many writes to the database, thus avoiding
too frequent write-locks.
Log message buffer flush happens when the buffer is full, when a critical log message is emitted, and also periodically.
An early buffer flush can happen when a critical message is emitted.
And in order to avoid messages to stay indefinitively in the buffer queue before appearing in database, a periodical
flush happens every X seconds.

This periodical flush can also be deactivated with ``buffer_periodical_flush_timing=False``, thus avoiding
the timer thread to be created.

Buffer size is configurable, as well as the log level for early flush (default is ``logging.CRITICAL``):

.. code-block:: python

 import logging
 from log4mongo.handlers import BufferedMongoHandler

 handler = BufferedMongoHandler(host='localhost',                          # All MongoHandler parameters are valid
                                capped=True,
                                buffer_size=100,                           # buffer size.
                                buffer_periodical_flush_timing=10.0,       # periodical flush every 10 seconds
                                buffer_early_flush_level=logging.CRITICAL) # early flush level

 logger = logging.getLogger().addHandler(handler)


Test
-----

** Tested on evnironment **

- Ubuntu 18.04
- python >=3.6.4
- pymongo >=3.9.0
- mongod - db version 4.0.13
- pytest

**Running tests**

Before you run the test you must start mongo database. You will do so by this command:

.. code-block::

 $ mongod --dbpath /tmp/


To run the test run command:

.. code-block::

 $ python3 setup.py test


See vagrant file to quickly setup the test environment.

Original Author
---------------

| char0n (Vladimir Gorej)
| email: vladimir.gorej@gmail.com
| web: https://www.linkedin.com/in/vladimirgorej/

Current Maintainer
------------------
| Oz Nahum Tiram
| email: oz.tiram@gmail.com
| web: https://oz123.github.io

References
----------
- http://www.mongodb.org/
- http://docs.python.org/library/logging.html
- http://github.com/mongodb/mongo-python-driver
- http://log4mongo.org
