06.01.2019       Выпуск 263 (31.12.2018 - 06.01.2019)       Статьи

Кэширование шаблонов для различных типов контента

В статье "Различные шаблоны для рендеринга разных типов контента в поисковой выдаче" было показано, как сделать рендеринг различных шаблонов в зависимости от того, какой тип контента отрисовывается в поисковой выдаче на сайте. При этом ключевым моментом являлось то, что не приходилось делать проверочные условия для выбор шаблона. Информация о шбалоне хранилась в переменной TEMPLATE_PREVIEW, через которую шаблон подставлялся в include тег в шаблоне Django. В данном способе есть один большой недостаток. Дело в том, что тег include при каждом своём вызове ищет шаблон. Его необходимо было как-то кэшировать, что и решается в данной статье.

Читать>>




Экспериментальная функция:

Ниже вы видите текст статьи по ссылке. По нему можно быстро понять ссылка достойна прочтения или нет

Просим обратить внимание, что текст по ссылке и здесь может не совпадать.

В Django - Урок 035. Различные шаблоны для рендеринга разных типов контента в поисковой выдаче было показано, как сделать рендеринг различных шаблонов в зависимости от того, какой тип контента отрисовывается в поисковой выдаче на сайте. При этом ключевым моментом являлось то, что не приходилось делать проверочные условия для выбор шаблона. Информация о шбалоне хранилась в переменной TEMPLATE_PREVIEW, через которую шаблон подставлялся в include тег в шаблоне Django.

{% include object.TEMPLATE_PREVIEW %}

В данном способе есть один большой недостаток. Дело в том, что тег include при каждом своём вызове ищет шаблон. При большой нагрузке на сайт - это может значительно увеличить длительность ответа от сервера. Чтобы решить эту проблему, необходимо каким-то образом закэшировать шаблон. Поскольку разные виды контента используют различные шаблоны, то сделать это с использованием inclusion_tag является довольно проблематичным.

Решить данную проблему удалось с помощью кэширования шаблона на уровне класса в качестве классовой переменной.

Реализовать данный механизм можно с помощью миксина

class EInterfaceMixin:
    TEMPLATE_FULL = 'full.html'     # путь к шаблону
    template_full = None            # переменная для кэширования шаблона

    # кэшировать будем с помощью классового метода, в который передаём объект для рендеринга, а также context запроса
    # контекст запроса необходим, чтобы обеспечить функционал рендеринга, имеющий зависимость на текущего пользователя
    @classmethod
    def __render_template_full(cls, obj, request_context):
        if not cls.template_full:
            cls.template_full = loader.get_template(cls.TEMPLATE_FULL)
        return cls.template_full.render({'object': obj, 'user': request_context['user']})

    # метод для выполнения рендеринга с использованием контекста
    def render_template_full(self, request_context):
        return self.__render_template_full(self, request_context)

Далее нужно зарегистрировать built-in тег. Это необходимо, чтобы при рендеринге в шаблоне забрать контекст запроса. В моём случае часть шаблонов не могут быть корректно отображены без информации о текущем пользователе, который находится на сайте.

@register.simple_tag(takes_context=True)
def render_template_full(context, obj):
    if obj:
        return obj.render_template_full(context)
    return ''

Использование в шаблоне

{% load render_template_full from core %}
{% for object in object_list %}
    {% render_template_full object %}
{% empty %}

Заключение

Этот миксин можно добавить ко всем моделям, которые будут использовать данный механизм рендеринга.

При первом вызове классового метода будет выполнено кеширование шаблона. При последущих вызовах рендеринга будет исползоваться уже закешированный шаблон. Таким образом не будет бесполезного расхода процессорного времени на поиск шаблонов при каждом вызове тега include






Разместим вашу рекламу

Пиши: mail@pythondigest.ru

Нашли опечатку?

Выделите фрагмент и отправьте нажатием Ctrl+Enter.

Система Orphus