Friday, May 3, 2013

Unable to configure handler 'console': __init__() got an unexpected keyword argument 'strm'

Django and upgraded from 2.6 to Python 2.7

Hopefuly this quick post will save someone time, I recently upgraded our Debian servers from stable (squeeze) to testing (wheezy).

Unfortunately this resulted in an odd error:

Traceback (most recent call last):
  File "manage.py", line 12, in 
    execute_from_command_line(sys.argv)
  File "/srv/www/django/development.FOO.com/virtualenv/src/github-django-django-stable/django/core/management/__init__.py", line 453, in execute_from_command_line
    utility.execute()
  File "/srv/www/django/development.FOO.com/virtualenv/src/github-django-django-stable/django/core/management/__init__.py", line 392, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "/srv/www/django/development.FOO.com/virtualenv/src/github-django-django-stable/django/core/management/__init__.py", line 263, in fetch_command
    app_name = get_commands()[subcommand]
  File "/srv/www/django/development.FOO.com/virtualenv/src/github-django-django-stable/django/core/management/__init__.py", line 109, in get_commands
    apps = settings.INSTALLED_APPS
  File "/srv/www/django/development.FOO.com/virtualenv/src/github-django-django-stable/django/conf/__init__.py", line 53, in __getattr__
    self._setup(name)
  File "/srv/www/django/development.FOO.com/virtualenv/src/github-django-django-stable/django/conf/__init__.py", line 49, in _setup
    self._configure_logging()
  File "/srv/www/django/development.FOO.com/virtualenv/src/github-django-django-stable/django/conf/__init__.py", line 84, in _configure_logging
    logging_config_func(self.LOGGING)
  File "/usr/lib/python2.7/logging/config.py", line 777, in dictConfig
    dictConfigClass(config).configure()
  File "/usr/lib/python2.7/logging/config.py", line 575, in configure
    '%r: %s' % (name, e))
ValueError: Unable to configure handler 'console': __init__() got an unexpected keyword argument 'strm'
(virtualenv)root@klisrv10:/srv/www/django/development.FOO.com/src/django-project#

The solution is relatively simple but not easily foundable in Google or Bing. The logging definition in settings.py needs to be updated to use the new Python 2.7 'stream' keyword argument instead of 'strm'. My updated default project logging settings below:

LOGGING = {
 'version': 1,
 'disable_existing_loggers': True,
 'filters': {
        'require_debug_false': {
            '()': 'django.utils.log.RequireDebugFalse'
        }
    },
 'formatters': {
  'verbose': {
   'format': '%(levelname)s %(name)s %(asctime)s %(module)s %(process)d %(thread)d %(pathname)s@%(lineno)s: %(message)s'
  },
  'simple': {
   'format': '%(levelname)s %(name)s %(filename)s@%(lineno)s: %(message)s'
  },
 },
  # let the 'handlers' get all messages and filter level in 'loggers'
 'handlers': {
  'null': {
   #'level':'DEBUG',
   'class':'django.utils.log.NullHandler',
  },
  'console':{
   #'level':'WARNING',
   'class':'logging.StreamHandler',
   'formatter': 'simple',
   'stream': sys.stderr,
   # 'stream': sys.stdout
   # see https://code.google.com/p/modwsgi/wiki/ApplicationIssues#Writing_To_Standard_Output
   
  },
  'mail_admins': {
   #'level': 'ERROR',
   'filters': ['require_debug_false'],
   'class': 'django.utils.log.AdminEmailHandler',
   'formatter': 'verbose'
  }
 },
 'loggers': {
  # catch all logger ex. any logger = logging.getLogger(__name__)
  '': { 
   'handlers': ['mail_admins', 'console'],
   'level': 'WARNING',
  },
 }
}

As always if you found this useful feel free to follow me here or via twitter @danielsokolowski.

No comments:

Post a Comment