Ускоряем работу сайта: используем Redis для кеширования и хранения данных

Redis — сетевое журналируемое хранилище данных типа «ключ — значение», которое обрабатывает данные в оперативной памяти и обладает механизмами снимков и журналирования для обеспечения постоянного хранения. Хранилище поддерживает работу с пятью типами данных: со строками, списками, хешами, обычными и сортируемыми множествами.

Redis отлично дополняет классические решения для хранения и обработки данных, будь то реляционные системы управления базами данных, документо-ориентированные хранилища или что-то иное. Redis подходит как для решения специфических задач, так и для использования в качестве основного хранилища для сайта или веб-приложения. На практике очень часто Redis используется для хранения очередей заданий, кеширования, фильтрации объектов, а также для хранения и обработки статистических данных.

Redis обрабатывает данные в RAM, а также персистирует их на диск (с частотой, зависящей от настроек). По сути, это даёт очень высокую скорость обработки данных в сочетании с достаточной надёжностью. Redis без проблем работает на большинстве POSIX систем, таких как Linux, *BSD, Mac OS X. Для обращений к хранилищу используется либо TCP/IP, либо сокеты. Распространяется Redis под лицензией BSD.

Использование Redis позволяет существенно ускорить работу сайта или веб-приложения, особенно на задачах, связанных с ведением статистики, в выполнении отложенных заданий с построением очередей и фоновой обработкой, а также при использовании Redis в качестве кеширующего хранилища.

Redis (remote dictionary server) — NoSQL СУБД, работающая со структурами данных типа «ключ-значение».

Redis в первую очередь ориентирован на быстрое выполнение атомарных операций. Данные хранятся в оперативной памяти, что обеспечивает очень быстрый доступ к ним. Наиболее активное применение он находит в кэшировании и в реализации брокеров сообщений и очередей.

Узнать больше →

Мы разрабатываем сайты, которые работают по-настоящему быстро: генерация страниц осуществляется за доли секунды, а загрузка сайта даже на медленных каналах занимает не более пары секунд.

Скорость работы веб-приложений очень важна для коммерческих проектов: пользователи не любят ждать и если сайт работает недостаточно быстро, то это их раздражает и они просто уходят. В системах для автоматизации бизнес-процессов показатель скорости работы тоже очень важен — продуктивность работы страдает, если система «зависает» или «тормозит».

Узнать больше →

Скорость работы веб-приложения — одна из ключевых метрик качества реализации проекта, значительно влияющая на коммерческую эффективность.

Cтатьи по теме:

Ускоряем работу сайта при помощи кеширования на базе Memcached
Memcached — это хранилище «ключ => значение», использование которого очень эффективно для ускорения работы сайта или веб-приложения.
MySQL — система управления базами данных
MySQL — это реляционная система управления базами данных с открытым исходным кодом. В настоящее время эта СУБД одна из наиболее популярных в веб-приложениях — подавляющее большинство CMS использует именно MySQL (часто только её, без альтернатив), а почти все веб-фреймворки поддерживают MySQL уже на уровне базовой конфигурации (без дополнительных модулей).
MariaDB — система управления реляционными базами данных
MariaDB — ответвление реляционной СУБД MySQL, разрабатываемое сообществом под лицензией GPL. MariaDB полностью совместима с приложениями, использующими MySQL, а переход на эту СУБД оправдан тем, что MySQL уже не так активно развивается.
PostgreSQL — свободная объектно-реляционная система управления базами данных
PostgreSQL — это популярная свободная объектно-реляционная система управления базами данных. PostgreSQL отличается высокой надёжность, базируется на языке SQL и имеет широкие возможности.
SQL-инъекции — распространённый метод взлома веб-приложений и сайтов
SQL-инъекции — это один из распространённых способов взлома сайтов и веб-приложений, работающих с реляционными базами данных. Этот способ основан на внедрении в выполняемый приложением запрос к базе данных произвольного SQL-кода, переданного злоумышленником.
Быстрый поиск на сайте, используя ElasticSearch или Sphinx
Sphinx и ElasticSearch — это поисковые «движки», которые обеспечивают более быстрый поиск и фильтрацию по сравнению с реляционными базами данных, а также обеспечивают возможность использования многих полезных функций поиска, например, учитывают морфологию языка, осуществляют фасеточный поиск, работают со стоп-словами, обеспечивают выборочную индексацию и позволяют производить настройку формулы определения релевантности документов.
Масштабирование баз данных — партиционирование, репликация и шардинг
СУБД — это очень часто «узкое место» в производительности веб-приложений. В момент, когда сервер баз данных не может справится с нагрузками, производится масштабирование. Рассмотрим основные способы увеличения производительности СУБД.

Тематические технологии:

Поисковая система ElasticSearch
PostgreSQL — объектно-реляционная СУБД
Колоночная СУБД Scylla
Колоночная СУБД Cassandra
Язык программирования Ruby
Фреймворк Ruby on Rails
Язык программирования Python
Язык программирования Go