[Zope-Checkins] CVS: ZODB3/zLOG - EventLogger.py:1.5
Guido van Rossum
guido@python.org
Tue, 7 Jan 2003 13:35:14 -0500
Update of /cvs-repository/ZODB3/zLOG
In directory cvs.zope.org:/tmp/cvs-serv11955
Modified Files:
EventLogger.py
Log Message:
Several changes, mostly to speed up logging when :
- Cache the translations from severity to level and string in dicts,
so these are normally done with a single dict.get() call rather than
a Python function call.
- Extract the PEP 282 level first, and check it against the effective
level of the logger, so we can take an early exit if the logger
won't handle the event.
- Got rid of textwrap. It slows things down, can frustrate grepping
programs, and wasn't effective unless you were using Python 2.3
anyway.
- Got rid of the addHandler(NullHandler()) (seems like superstition).
- Got rid of the log_format class variable (YAGNI).
=== ZODB3/zLOG/EventLogger.py 1.4 => 1.5 ===
--- ZODB3/zLOG/EventLogger.py:1.4 Tue Dec 17 13:02:30 2002
+++ ZODB3/zLOG/EventLogger.py Tue Jan 7 13:35:12 2003
@@ -19,46 +19,36 @@
__version__='$Revision$'[11:-2]
-import os, time
-try:
- import textwrap
-except ImportError:
- textwrap = None
+import os, sys, time
import logging
from BaseLogger import BaseLogger
from LogHandlers import FileHandler, NullHandler, SysLogHandler
from logging import StreamHandler, Formatter
class EventLogger(BaseLogger):
+
logger = logging.getLogger('event')
- logger.addHandler(NullHandler())
- log_format = '%(sev)s %(subsys)s %(summary)s%(detail)s'
def log(self, subsystem, severity, summary, detail, error):
- if error:
- kw = {'exc_info':1}
- else:
- kw = {}
+
+ level = (zlog_to_pep282_severity_cache_get(severity) or
+ zlog_to_pep282_severity(severity))
+
+ # Try an early exit if the logger is disabled for this level.
+ # (XXX This inlines logger.isEnabledFor(level).)
+ if (self.logger.manager.disable >= level or
+ level < self.logger.getEffectiveLevel()):
+ return
+
+ msg = "%s %s %s" % (
+ severity_string_cache_get(severity) or severity_string(severity),
+ subsystem,
+ summary)
if detail:
- detail = '\n' + detail
- else:
- detail = ''
-
- msg = self.log_format % {
- 'sev' : severity_string(severity),
- 'subsys' : subsystem,
- 'summary': summary,
- 'detail' : detail,
- }
-
- if textwrap and len(msg) > 80:
- msg = '\n'.join(textwrap.wrap(
- msg, width=79, subsequent_indent=" "*20,
- break_long_words=0))
+ msg = "%s\n%s" % (msg, detail)
- severity = zlog_to_pep282_severity(severity)
- self.logger.log(severity, msg, **kw)
+ self.logger.log(level, msg, exc_info=(error is not None))
event_logger = EventLogger()
@@ -77,6 +67,11 @@
s = mapping.get(int(severity), '')
return "%s(%s)" % (s, severity)
+severity_string_cache = {}
+for _sev in range(-300, 301, 100):
+ severity_string_cache[_sev] = severity_string(_sev)
+severity_string_cache_get = severity_string_cache.get
+
def zlog_to_pep282_severity(zlog_severity):
"""
We map zLOG severities to PEP282 severities here.
@@ -101,6 +96,11 @@
return logging.INFO
else:
return logging.DEBUG
+
+zlog_to_pep282_severity_cache = {}
+for _sev in range(-300, 301, 100):
+ zlog_to_pep282_severity_cache[_sev] = zlog_to_pep282_severity(_sev)
+zlog_to_pep282_severity_cache_get = zlog_to_pep282_severity_cache.get
def log_time():
"""Return a simple time string without spaces suitable for logging."""