Merge "add support for custom log handlers"

This commit is contained in:
Jenkins 2012-10-05 21:34:48 +00:00 committed by Gerrit Code Review
commit 1ef17d8284
6 changed files with 34 additions and 0 deletions

View File

@ -13,6 +13,10 @@
# log_facility = LOG_LOCAL0 # log_facility = LOG_LOCAL0
# log_level = INFO # log_level = INFO
# log_address = /dev/log # log_address = /dev/log
# comma separated list of functions to call to setup custom log handlers.
# functions get passed: conf, name, log_to_console, log_route, fmt, logger,
# adapted_logger
# log_custom_handlers =
# If set, log_udp_host will override log_address # If set, log_udp_host will override log_address
# log_udp_host = # log_udp_host =
# log_udp_port = 514 # log_udp_port = 514

View File

@ -16,6 +16,10 @@
# log_facility = LOG_LOCAL0 # log_facility = LOG_LOCAL0
# log_level = INFO # log_level = INFO
# log_address = /dev/log # log_address = /dev/log
# comma separated list of functions to call to setup custom log handlers.
# functions get passed: conf, name, log_to_console, log_route, fmt, logger,
# adapted_logger
# log_custom_handlers =
# If set, log_udp_host will override log_address # If set, log_udp_host will override log_address
# log_udp_host = # log_udp_host =
# log_udp_port = 514 # log_udp_port = 514

View File

@ -6,6 +6,10 @@
# log_facility = LOG_LOCAL0 # log_facility = LOG_LOCAL0
# log_level = INFO # log_level = INFO
# log_address = /dev/log # log_address = /dev/log
# comma separated list of functions to call to setup custom log handlers.
# functions get passed: conf, name, log_to_console, log_route, fmt, logger,
# adapted_logger
# log_custom_handlers =
# If set, log_udp_host will override log_address # If set, log_udp_host will override log_address
# log_udp_host = # log_udp_host =
# log_udp_port = 514 # log_udp_port = 514

View File

@ -14,6 +14,10 @@
# log_facility = LOG_LOCAL0 # log_facility = LOG_LOCAL0
# log_level = INFO # log_level = INFO
# log_address = /dev/log # log_address = /dev/log
# comma separated list of functions to call to setup custom log handlers.
# functions get passed: conf, name, log_to_console, log_route, fmt, logger,
# adapted_logger
# log_custom_handlers =
# If set, log_udp_host will override log_address # If set, log_udp_host will override log_address
# log_udp_host = # log_udp_host =
# log_udp_port = 514 # log_udp_port = 514

View File

@ -15,6 +15,10 @@
# log_level = INFO # log_level = INFO
# log_headers = False # log_headers = False
# log_address = /dev/log # log_address = /dev/log
# comma separated list of functions to call to setup custom log handlers.
# functions get passed: conf, name, log_to_console, log_route, fmt, logger,
# adapted_logger
# log_custom_handlers =
# If set, log_udp_host will override log_address # If set, log_udp_host will override log_address
# log_udp_host = # log_udp_host =
# log_udp_port = 514 # log_udp_port = 514

View File

@ -689,6 +689,20 @@ def get_logger(conf, name=None, log_to_console=False, log_route=None,
logger.statsd_client = None logger.statsd_client = None
adapted_logger = LogAdapter(logger, name) adapted_logger = LogAdapter(logger, name)
other_handlers = conf.get('log_custom_handlers', None)
if other_handlers:
log_custom_handlers = [s.strip() for s in other_handlers.split(',')
if s.strip()]
for hook in log_custom_handlers:
try:
mod, fnc = hook.rsplit('.', 1)
logger_hook = getattr(__import__(mod, fromlist=[fnc]), fnc)
logger_hook(conf, name, log_to_console, log_route, fmt,
logger, adapted_logger)
except (AttributeError, ImportError):
print >>sys.stderr, 'Error calling custom handler [%s]' % hook
except ValueError:
print >>sys.stderr, 'Invalid custom handler format [%s]' % hook
return adapted_logger return adapted_logger