A package for pushing serialized error log which generated by loguru to remote storage like mongodb / redis / fluentd
Project description
logger-master
A package for pushing serialized error log which generated by loguru to remote storage.
Description:
A package for pushing serialized error log which generated by loguru to remote storage (including mongodb / redis / fluentd).
How To Use:
With MongoDB
- parameters:
- mongo_instance(object): mongodb instance
- mongo_db(str): database for storing log data
- mongo_collection(str): collection for storing log data
- terminal_displayed(bool): display log information on terminal screen or not
- rotation(str): loguru rotation
- serialize(bool): data serialized or not
- log_format(str): loguru format
- log_path(str): file path for storing log data
- custom_func(function): function for custom serialized data
import json
from pymongo import MongoClient
from logger_master.logger import MongoLogger
# pushing log to mongodb instance
mongo_uri = 'mongodb://root:root@localhost:27017/?authMechanism=SCRAM-SHA-1'
mongo_instance = MongoClient(mongo_uri)
# basic usage for pushing log with specific database and collection
logger = MongoLogger(mongo_instance=mongo_instance,
mongo_db='my_log',
mongo_collection='my_log_collection')
# pushing serialize log to ./my_log/log_file
logger = MongoLogger(mongo_instance=mongo_instance,
mongo_db='my_log',
mongo_collection='my_log_collection',
serialize=True,
log_path='./my_log/log_file',
rotation='1 week')
# disable display log on screen
logger = MongoLogger(mongo_instance=mongo_instance,
mongo_db='my_log',
mongo_collection='my_log_collection',
log_path='./my_log/log_file',
terminal_displayed=False)
# pushing serialized log with custom format
def custom_function(serialized_data):
if not isinstance(serialized_data, dict):
serialized_data = json.loads(serialized_data)
serialized_data.update({'new_key': 'new_value'})
return serialized_data
logger = MongoLogger(mongo_instance=mongo_instance,
mongo_db='my_log',
mongo_collection='my_log_collection',
custom_func=custom_function)
try:
100 / 0
except Exception as e:
logger.error(str(e))
With Redis
- parameters:
- redis_instance(object): redis instance
- key_prefix(str): prefix for redis key
- terminal_displayed(bool): display log information on terminal screen or not
- rotation(str): loguru rotation
- serialize(bool): data serialized or not
- log_format(str): loguru format
- log_path(str): file path for storing log data
- custom_func(function): function for custom serialized data
import json
import redis
from logger_master.logger import RedisLogger
# basic usage for pushing log to redis instance
redis_instance = redis.StrictRedis(host='localhost',
password='root',
port='root')
# pushing log to mongodb with 'my_error_log' key prefix
logger = RedisLogger(redis_instance=redis_instance,
key_prefix='my_error_log')
# pushing serialize log to ./my_log/log_file
logger = RedisLogger(redis_instance=redis_instance,
key_prefix='my_error_log',
serialize=True,
log_path='./my_log/log_file',
rotation='1 week')
# disable display log on screen
logger = RedisLogger(redis_instance=redis_instance,
key_prefix='my_error_log',
log_path='./my_log/log_file',
terminal_displayed=False)
# pushing serialized log with custom format
def custom_function(serialized_data):
if not isinstance(serialized_data, dict):
serialized_data = json.loads(serialized_data)
serialized_data.update({'new_key': 'new_value'})
return serialized_data
logger = RedisLogger(redis_instance=redis_instance,
key_prefix='my_error_log',
custom_func=custom_function)
try:
100 / 0
except Exception as e:
logger.error(str(e))
With Fluentd
- parameters:
- hostname(str): fluentd hostname
- port(int): fluentd port
- key_prefix(str): prefix for fluentd key
- terminal_displayed(bool): display log information on terminal screen or not
- rotation(str): loguru rotation
- serialize(bool): data serialized or not
- log_format(str): loguru format
- log_path(str): file path for storing log data
- custom_func(function): function for custom serialized data
import json
from logger_master import FluentdLogger
# pushing log log to fluentd
# basic usage for pushing log data to fluentd
logger = FluentdLogger(hostname='localhost',
port=24224,
key_prefix='mongo')
# pushing serialize log to ./my_log/log_file
logger = FluentdLogger(hostname='localhost',
port=24224,
key_prefix='mongo',
serialize=True,
log_path='./my_log/log_file',
rotation='1 week')
# disable display log on screen
logger = FluentdLogger(hostname='localhost',
port=24224,
key_prefix='mongo',
log_path='./my_log/log_file',
terminal_displayed=False)
# pushing serialized log with custom format
def custom_function(serialized_data):
if not isinstance(serialized_data, dict):
serialized_data = json.loads(serialized_data)
serialized_data.update({'new_key': 'new_value'})
return serialized_data
logger = FluentdLogger(hostname='localhost',
port=24224,
key_prefix='mongo',
custom_func=custom_function)
try:
1 / 0
except Exception as e:
logger.error(msg=str(e))
you can also push log to both fluentd and mongodb with fluent-plugin-mongo.
Buy me a coffee, if you like it!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file logger-master-0.0.3.tar.gz.
File metadata
- Download URL: logger-master-0.0.3.tar.gz
- Upload date:
- Size: 5.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.2.0 requests-toolbelt/0.9.1 tqdm/4.50.0 CPython/3.8.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4af544d2275ec6eeb38624633f7eb02b1bc6d5cf06e716d5099a89ab1b6a0772
|
|
| MD5 |
2bdd08e6cfa4a1874b6e3134f01f08ad
|
|
| BLAKE2b-256 |
2ecb81d39e7a4085ea9259dedffcbabc56a34c52e62b04870c1f183837ddfee4
|
File details
Details for the file logger_master-0.0.3-py3-none-any.whl.
File metadata
- Download URL: logger_master-0.0.3-py3-none-any.whl
- Upload date:
- Size: 5.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.2.0 requests-toolbelt/0.9.1 tqdm/4.50.0 CPython/3.8.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d329ba814cfd0938dc6fb395e93ab36a08e47c407f743b016135ae5c782a2949
|
|
| MD5 |
35b53e95edb64a9b2c57ca53d9e34838
|
|
| BLAKE2b-256 |
aeb68c2b6c8c04c9080072ba25ea6da84180bc31d5a46e421c0d75d8a474a1e9
|