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, inexecute_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.
Comments
Post a Comment