Карты сайта Django отлично работали на предыдущем сервере и отлично работают в моей среде разработки, но перерыв в работе на новом сервере:
ValidationError: [u'Unknown timezone '] (обратная связь ниже),Я также получал похожую ошибку при попытке доступа к одной из наших моделей от администратора.
Обновление:
Путь build / bdist.linux-x86_64 / egg / timezones в трассировке подсказал мне, что происходили странные пути.Оказалось, что кто-то скопировал кучу вещей с другого сервера, а не делал правильные установки pip.Я удалил несколько старых библиотек, исправил путь по умолчанию для virtualenv и установил pjj-временные зоны.Теперь все работает хорошо.Оставьте это на тот случай, если это пригодится кому-либо еще.
В файлах карты сайта ничего не говорится о конфигурации или зависимостях часового пояса: https://docs.djangoproject.com/en/dev/ref/contrib/sitemaps/
Часовой пояс сервера правильно установлен на Америку/ Los_Angeles, и я установил то же самое в settings.py Я не уверен, что еще посмотреть здесь, и Google ничего не показывает.
Я ссылаюсь на 8 моделей в своем определении SiteMaps в urls.py, но только одна BlogSiteMap вызывает сбой (если я закомментирую это, остановка будет прервана, но тогда у меня не будет сообщений блога в карте сайта.состоит из:
class BlogSitemap(Sitemap):
changefreq = "weekly"
priority = 0.7
def items(self):
return Post.objects.filter(status=2).order_by('-modified')
def lastmod(self, obj):
return obj.modified
Модель блога Поста такая (немного отредактировано для краткости)
class Post(models.Model):
"""Post model."""
title = models.CharField(_('title'), max_length=200)
slug = models.SlugField(_('slug'), unique_for_date='publish')
author = models.ForeignKey(User, blank=True, null=True)
body = models.TextField(_('body'))
tease = models.TextField(_('tease'), blank=True)
status = models.IntegerField(_('status'), choices=STATUS_CHOICES, default=2)
allow_comments = models.BooleanField(_('allow comments'), default=True)
fp_show = models.BooleanField('Show on homepage',default=False)
order = models.IntegerField(blank=True, null=True)
publish = models.DateTimeField(_('publish'),default=datetime.now())
created = models.DateTimeField(_('created'), auto_now_add=True)
modified = models.DateTimeField(_('modified'), auto_now=True)
categories = models.ManyToManyField(Category, blank=True)
tags = TagField()
objects = PublicManager()
def __unicode__(self):
return u'%s' % self.title
@permalink
def get_absolute_url(self):
return ('blog_detail', None, {
'year': self.publish.year,
'month': self.publish.strftime('%b').lower(),
'day': self.publish.day,
'slug': self.slug
})
Использование: Django 1.3 Python 2.7 RHEL 5.7
Спасибо.
Traceback (most recent call last):
File "/home/username/virtualenvs/kdmc/lib/python2.7/site-packages/django/core/handlers/base.py", line 111, in get_response
response = callback(request, *callback_args, **callback_kwargs)
File "/home/username/virtualenvs/kdmc/lib/python2.7/site-packages/django/contrib/sitemaps/views.py", line 39, in sitemap
urls.extend(site().get_urls(page=page, site=current_site))
File "/home/username/virtualenvs/kdmc/lib/python2.7/site-packages/django/contrib/sitemaps/__init__.py", line 75, in get_urls
for item in self.paginator.page(page).object_list:
File "/home/username/virtualenvs/kdmc/lib/python2.7/site-packages/django/db/models/query.py", line 107, in _result_iter
self._fill_cache()
File "/home/username/virtualenvs/kdmc/lib/python2.7/site-packages/django/db/models/query.py", line 772, in _fill_cache
self._result_cache.append(self._iter.next())
File "/home/username/virtualenvs/kdmc/lib/python2.7/site-packages/django/db/models/query.py", line 286, in iterator
obj = model(*row[index_start:aggregate_start])
File "/home/username/virtualenvs/kdmc/lib/python2.7/site-packages/django/db/models/base.py", line 297, in __init__
setattr(self, field.attname, val)
File "/home/username/virtualenvs/kdmc/lib/python2.7/site-packages/django/db/models/fields/subclassing.py", line 99, in __set__
obj.__dict__[self.field.name] = self.field.to_python(value)
File "build/bdist.linux-x86_64/egg/timezones/fields.py", line 43, in to_python
return coerce_timezone_value(value)
File "build/bdist.linux-x86_64/egg/timezones/utils.py", line 34, in coerce_timezone_value
raise ValidationError("Unknown timezone")
ValidationError: [u'Unknown timezone']