Последние сообщения

Инвитро
Инвитро
  • Сообщений: 1
  • Последний визит: 16 апреля 2025 в 21:34

MVC — это архитектурный паттерн, который разделяет приложение на три логических компонента: модель, представление и контроллер. 

Основная идея паттерна MVC в том, что у каждого раздела кода есть своя цель. Часть кода содержит данные приложения, другая отвечает за то, каким его видит пользователь, последняя управляет его работой.

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

— Код внешнего вида приложения, View, состоит из функций, которые отвечают за интерфейс и способы взаимодействия пользователя с ним. Представления создают на основе данных, собранных из модели. В случае приложения со списком дел View определяет, как выглядят задачи.

— Код контроллера, Controller, связывает модель и представление. Он получает на вход пользовательский ввод, интерпретирует его и информирует о необходимых изменениях. Например, отправляет команды для обновления состояния, такие как сохранение документа. В приложении со списком дел контроллер определяет, как пользователь добавляет задачу или помечает ее как выполненную.

Проще говоря — MVC — подход к проектированию приложения, который предполагает выделение кода в блоки типов модель, представление и контроллер. Контроллер обрабатывает входящие запросы. Модель достаёт из базы данных информацию, нужную для выполнения конкретных запросов. Представление определяет результат запроса, который получает пользователь. 

Таким образом DST Platform становиться логичным и понятным для почти любого разработчика, что достаточно важно т.к. нет привязки к чему то одному. 

Александр Репин
Александр Репин
  • Сообщений: 62
  • Последний визит: 27 августа 2025 в 13:52

Паттерн MVC позволяет писать независимые друг от друга блоки кода. Их можно менять отдельно, не затрагивая остальные. Так можно облегчить себе работу, разрабатывая только один программный компонент — независимо от остальных. Например, переписывать способ отображения данных, не трогая способ их обработки.

Это особенно актуально для больших команд. MVC структурирует код и упрощает тестирование, поддержку: с этим паттерном модернизировать можно отдельные блоки, а не всё приложение целиком. Модель позволяет разделить обязанности: пока один программист пишет обработчик данных, другой занят их отображением. В DST Platform это здорово экономит время: каждый работает над своей задачей, не нужно вникать в чужой код, а изменения в одном блоке не влияют на другой.

Редактировалось: 1 раз (Последний: 16 апреля 2025 в 21:29)
АйТи
АйТи
  • Сообщений: 7
  • Последний визит: 23 апреля 2025 в 12:10

Хотелось бы по подробней узнать, зачем использовать паттерн MVC в DST Platform? Какие вообще преимущества и минусы MVC. Также было здорово понять MVC в реальной веб-разработке: как работает контроллер?

Денис Наумов

Ну если просто то MVC помогает грамотно организовать собственный код — по функциям каждого конкретного блока. Это повышает его читаемость. Вам будет проще к нему возвращаться и дорабатывать, а другим разработчикам — легче его понять.

АйТи
АйТи
  • Сообщений: 7
  • Последний визит: 23 апреля 2025 в 12:10

Спасибо всем за ответы. Просто у нас переходов на сайт много, а обращений нет, как с этим быть?

Agrarium

Расскажу один интересный эксперимент, который проводил мой коллега. Был у него клиент юрист. Думали вместе, какой сделать сайт. Это было достаточно давно, тогда еще не было каких-то явных элементов, повышающих конверсию.

Решили поэкспериментировать и заказали сайт у трех разных разработчиков. Юристы вполне могут себе это позволить. Разработчики трех разных уровней: профессиональный опытный специалист, с небольшим опытом и студент. Кстати, третий согласился сделать бесплатно в качестве тренировки и наглядного материала для дипломной работы.

Первый сайт получился красивый, яркий, с акцентами. Смотришь, глаз не нарадуется. Второй сайт средний, как у всех, но тоже неплохой. А третий внешне вообще не привлекательный, чем-то похож на сайт гос.структры.

Запустили рекламу на все сайты одновременно. И что вы думаете – третий «убогонький» сайт побил все рекорды У него конверсия оказалась в 15% Это в 3 раза выше нормы. А все потому, что он вызывал доверие у посетителей сайта. В умах людей юрист – это дорого, если сильно роскошный сайт, значит этот юрист берет много денег.

А если сайт юриста простой, возможно, он работает от государства, цены на его услуги меньше. Сыграла чистая психология.

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

Agrarium
Agrarium
  • Сообщений: 3
  • Последний визит: 16 апреля 2025 в 21:10

Спасибо всем за ответы. Просто у нас переходов на сайт много, а обращений нет, как с этим быть?

АйТи
АйТи
  • Сообщений: 7
  • Последний визит: 23 апреля 2025 в 12:10

Кстати на CR влияет много факторов, так что не стоит считать его главной метрикой в маркетинге, которая отражает эффективность рекламы. CR — важный элемент общей картины, но вписывать его туда нужно осмысленно. В следующих статьях мы поговорим о том, на какие ещё показатели стоит обращать внимание. Учитывайте все каналы, по которым может прийти пользователь: не только заказы с сайта, но и звонки, офлайн-конверсии. Тогда вы точно оцените, сколько людей совершили целевое действие.

DST Global
DST Global
  • Сообщений: 57
  • Последний визит: 12 декабря 2025 в 21:11

Конверсия — это процент посетителей сайта, которые совершили определённое действие, например зарегистрировали профиль или заказали товар. В маркетинге для этого показателя используют обозначение CR, или conversion rate.

Эффект от рекламы не всегда соответствует бюджету на продвижение. Чтобы понять, какой результат принесла кампания, важно рассчитать конверсию. Всем, кто занимается интернет-маркетингом, полезно знать, что это и как работает.

Как вычислить коэффициент конверсии

Конверсия в Директе — это количество целевых визитов.

Целевое действие — то, ради чего проводится рекламная кампания. Оно может быть таким:

— Покупка → самое частое целевое действие
— Посещение разделов «Контакты», «Каталог», «Прайс» → для интернет⁠-⁠магазина, продающего сайта
— Заявка с просьбой предоставить информацию, вопрос → для сайта юридических услуг
— Регистрация на форуме или сайте → для информационного или игрового портала

Коэффициент конверсии (conversion rate, CR) — маркетинговый показатель, который помогает определить, как количество целевых действий соотносится с общим количеством посещений сайта или приложения. Например, цель кампании — собрать контакты потенциальных клиентов. Тогда каждое заполнение формы обратной связи будет увеличивать показатель CR.

Как посчитать конверсию в процентах:

CR = (Количество целевых визитов ÷ Общее количество посещений) × 100

Количество конверсий — это абсолютный показатель, а CR — относительный.

Чем CR отличается от CTR

С метрикой CR связан ещё один показатель конверсии.

Коэффициент кликабельности (click through rate, CTR) — отношение количества кликов к общему числу показов объявления или рекламного баннера.

Рассчитывается он по формуле, похожей на расчёт CR:

CTR = (Количество кликов ÷ Количество показов) × 100

При запуске кампании сначала обращают внимание на CTR:
он показывает процент пользователей, которые увидели рекламное объявление или баннер и перешли на сайт.

Дальше оценивают уже CR-конверсию — процент посетителей сайта, которые совершили целевое действие.

От чего зависит количество конверсий

— Рекламная кампания: релевантные ключевые запросы с минус-словами, тексты и посадочные страницы.
— Удобство сайта: навигация, простая форма заказа, быстродействие.
— Качество трафика: насколько клиент подготовлен и заинтересован в товарах и услугах. Например, человеку с идеальным зрением не нужны очки, даже самый продающий текст вам не поможет.
— Качественная работа с теми, кто совершил целевое действие. Надо быстро отправлять заказы и отвечать на письма, проводить грамотные консультации. Если это заявка — доведите человека до покупки, если заказ — превратите клиента в постоянного.
— Остальные причины, которые от вас не зависят: день недели, время суток, сезон, распродажи, праздники.

Как связаны конверсия и эффективность рекламы

С помощью коэффициента конверсии можно анализировать эффективность рекламной кампании. Но всегда ли высокий CR означает высокую эффективность?

Предположим, у нас есть два сайта.

Сайт 1: 5 000 посещений, 200 продаж. CR = 4%.
Сайт 2: 1 000 посещений, 100 продаж. CR = 10%.

CR второго более чем в два раза выше первого. Однако по посещаемости первый сайт в пять раз превосходит второй. При прочих равных условиях с точки зрения охвата аудитории первый случай тоже можно считать эффективным. Всё зависит от цели кампании, от цены привлечённого заказа и от того, окупились ли вложения в рекламу.

На что лучше ориентироваться, измеряя эффективность: CR или количество конверсий?

Представьте ситуацию: вы добавили в кампанию ключевые запросы, которые увеличили охват рекламы и количество кликов. Посетителей стало в три раза больше, но количество заказов не выросло. Таким образом, количество конверсий осталось прежним, а CR упал втрое.

Хорошо это или плохо — зависит от цели кампании. Если требовалось увеличить охват, то у вас всё получилось. А если повысить продажи — снижение CR говорит, что цели вы не достигли.

Важно разделять понятия «коэффициент конверсии» и «количество конверсий». Мы рекомендуем ориентироваться на CR: именно он характеризует качество трафика и в конечном счёте эффективность рекламной кампании.

Как повысить конверсию

Первый этап — исследование

Изучаем причины низкой конверсии (анализируем кампанию, сайт, работу с клиентами). Ищем способы, как устранить их. Собираем аналитику и формулируем гипотезу.

Если нужно увеличить CR, в первую очередь изучаем качество трафика и посадочные страницы; если количество конверсий — оцениваем ещё и количество трафика.

Второй этап — эксперимент

Устраняем причины низкой конверсии: оптимизируем кампанию, изменяем сайт. Например:

— Работаем с запросами — минус-слова, вложенные и нецелевые запросы, дубли, пересечения
— Пишем релевантные тексты
— Добавляем точные посадочные страницы
— Анализируем сайт, смотрим на него глазами потенциального покупателя
— Подбираем таргетинги: настраиваем рекламу на целевую аудиторию (ретаргетинг, сегменты аудитории)

Артем Матвеев
Артем Матвеев
  • Сообщений: 21
  • Последний визит: 1 декабря 2025 в 16:11

Какая конверсия сайта считается хорошей или должна быть

Но какую конверсию сайта можно посчитать хорошей? В среднем этот показатель колеблется от 0,5% до 14%. Однако, стоит говорить о том, что для одного сайта мало, для другого нормально. Например, первый ресурс выдает конверсию в 9%, а второй – 3%. Но, у второго сайта получается средний чек больше, а значит и прибыли будет больше. Получается, что второй ресурс со своими 3% выигрывает.

Поэтому говорить о конкретной цифре хорошей конверсии сайта для любого ресурса практически невозможно. Следует рассматривать этот показатель для конкретного сайта. Так, хорошая конверсия сайта – эта та, которая перекрывает траты владельца на рекламу, зарплату работникам, аренду помещения и другое.

Чтобы достигнуть такой конверсии, не следует забывать о таком определении, как воронка продаж, ведь клиент должен пройти все ее этапы, прежде чем купит вашу продукцию (товар/услугу). Вам нужно сначала привлечь внимание посетителя, потом заинтересовать его в продукции.

Следующим шагом станет сделать так, чтобы пользователь изъявил желание купить или добавить в корзину продукцию. И, наконец, сделал покупку.

Виды конверсии сайта

Теперь давайте поговорим о видах конверсии сайта. Их существует два. Это макроконверсия и микроконверсия. Остановимся на каждом из них для большего понимания этого показателя успешности интернет-продвижения.

Основой макроконверсии являются продажи, а именно целевые действия пользователей к соотношению общего числа аудитории сайта. Увеличить этот процент старается каждый предприниматель, ведь основными правилами бизнеса являются его развитие, постоянная прибыль, учитывание перспектив и другое.

А вот микроконверсия строится на шагах, которые совершает посетитель перед покупкой. Он тесно связан с воронкой продаж. От этого вида конверсии зависят результаты первого. Это, своего рода, промежуточный показатель, но при этом также очень важный. Анализируя его, можно выявить недостатки того, почему так мало посетителей совершают действие, и исправить недочет.

Конверсия сайта: какие факторы влияют

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

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

Во-вторых, на конверсию ресурса влияет его место в списке поисковых систем. Здесь говориться о SEO-продвижении по позициям с попаданием веб-ресурса в ТОП-10. Чем выше сайт в выдаче, тем больше вероятность того, что аудитория перейдет на него.

Внутренние факторы – это ваш ресурс. На них повлиять легче, ведь вы сами можете улучшить его, чтобы аудитория проводила на нем как можно больше времени.

Внутренние факторы, влияющие на конверсию сайта:

— Дизайн сайта. Он должен привлекать посетителей, а не отталкивать. Пренебрегать им не следует, так как это первое, что видит аудитория.

— Контент сайта. Он должен быть уникальным и информативным для аудитории чтобы они нашли всю интересующую их информацию.

— Юзабилити сайта. Веб-ресурс должен быть удобным в использовании, чтобы аудитория не запуталась при поиске ответов на свои вопросы.

— Техническое состояние веб-ресурса. Он дожжен быстро загружаться, быть без каких-либо ошибок (например, ошибка 404), без лишних страниц и многое другое.

— Семантическое ядро веб-ресурса. Оно должно быть грамотно и правильно составлено. Иначе это снизить вашу конверсию.

Повышение конверсии сайта: как улучшить

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

Способы по повышению конверсии:

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

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

— Страница с товаром или услугой должна содержать детальную информацию, чтобы потенциальный покупатель совершил покупку: описание продукта, его цена и т.д.

— На сайте должен быть раздел с информацией о компании: чем занимается, история, награды и т.д.

— Отзывы также должны быть. Они помогут потенциальному клиенту принять решение: покупать или нет.

— Покупка продукции должна быть простой и удобной. Постарайтесь убрать лишние действия.

— Не забывайте о правильной и четкой навигации. Она должна помогать найти ответ, а не запутывать еще больше.

Как узнать конверсию сайта?

Ответ на вопрос «Как узнать конверсию сайта?» также важен. В этом вам помогут сервисы для ее измерения. В основном, это Яндекс. Метрика и Google Analytics. Ранее мы писали о Яндекс.Метрике, а также говорили, что это такое Google Analytics и как работает. Эти сервисы бесплатны.

В Яндекс Метрике для начала следует поместить счетчик для определения числа пользователей и их действий. После этого следует задать цели, по которым сервис будет считать действия аудитории. В Метрике их четыре типа: число просмотренных страниц аудиторией веб-ресурса; число просмотров конкретной страницы сайта; событие, как удачный показатель для владельца веб-ресурса; постепенные шаги для совершения действия на веб-ресурсе.

Для счетчиков есть ограничение, а именно 100 целей. Поэтому в Метрике разработали и внедрили колонку с показателем отложенной конверсии. Она помогает узнать те переходы, которые пользователь совершил напрямую с адресной строки браузера.

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

Подводя итог, можно сказать, что конверсия сайта – один из наиважнейших показателей в интернет-продвижении. Если владелец веб-ресурса знает о проценте этого показателя, то он может поднять интерес аудитории к сайту, что приведет и к поднятию действий с ее стороны. Получается, что у компании повысится прибыль. Чего и добивается каждый бизнесмен.

АйТи
АйТи
  • Сообщений: 7
  • Последний визит: 23 апреля 2025 в 12:10

Я хочу использовать Redis в качестве базы данных на DST Platform, а не кэша. Насколько я (ограниченно) понимаю, Redis — это хранилище данных в оперативной памяти. Каковы риски при использовании Redis и как их можно снизить?

Евгений Абрамов

Поскольку Redis — это хранилище в оперативной памяти, вы не можете хранить большие объёмы данных, которые не помещаются в память вашего компьютера. Обычно Redis работает очень плохо, если объём хранимых данных превышает 1/3 объёма оперативной памяти. Таким образом, это серьёзное ограничение при использовании Redis в качестве базы данных.

Конечно, вы можете распределить большие данные по нескольким экземплярам Redis, но вам придётся делать это вручную. Обычно эта операция выполняется следующим образом (при условии, что изначально у вас есть только один экземпляр):

— Используйте механизм «ведущий-ведомый» для репликации данных на второй компьютер. Теперь у вас есть две копии одних и тех же данных.

— Оборвите соединение между ведущим и ведомым устройством.

— Удалите первую половину (разделенную с помощью хеширования и т. д.) данных на первом компьютере и удалите вторую половину данных на втором компьютере.

— Скажите всем клиентам (PHP, C и т. д.) работать на первом компьютере, если указанные ключи находятся на этом компьютере, в противном случае работайте на втором компьютере.

Именно так масштабируется Redis! Вам также нужно остановить свой сервис, чтобы предотвратить запись данных во время миграции.

Исходя из нашего опыта, мы пришли к следующему выводу о Redis: Redis не подходит для хранения более 30 ГБ данных, Redis не масштабируется, Redis вполне подходит для разработки прототипов.

Позже мы нашли альтернативу Redis — SSDB(github.com/ideawu/ssdb), сервер уровня БД, который поддерживает почти все API-интерфейсы Redis и подходит для хранения более 1 ТБ данных, что зависит только от размера вашего жёсткого диска.

Agrarium
Agrarium
  • Сообщений: 3
  • Последний визит: 16 апреля 2025 в 21:10

Я хотел бы поделиться некоторыми вещами, которые мы узнали, используя Redis в качестве основной базы данных в нашем сервисе на базе DST Platform. Мы выбрали Redis, потому что у нас были данные, которые нельзя было разделить на разделы. Мы хотели добиться максимальной производительности от одного сервера

Плюсы:

— Redis был непревзойденным по производительности. Мы получали 10 000 транзакций в секунду «из коробки» (обратите внимание, что одна транзакция включала в себя несколько команд Redis). После нескольких оптимизаций и использования скриптов LUA мы смогли достичь скорости 25 000+ транзакций в секунду. Таким образом, когда дело касается производительности на один сервер, Redis не имеет себе равных.

— Redis очень прост в настройке и имеет очень небольшую кривую обучения по сравнению с другими хранилищами данных SQL и NoSQL.

Минусы:

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

— Самая большая проблема, с которой мы столкнулись при работе с Redis, — это отсутствие гибкости. Как только вы определяете структуру своих данных, любые изменения в требованиях к хранилищу или шаблонах доступа практически требуют переосмысления всего решения. Не уверен, что это относится ко всем хранилищам данных NoSQL (я слышал, что MongoDB более гибкая, но сам её не использовал).

— Поскольку Redis работает в однопоточном режиме, загрузка процессора очень низкая. Вы не можете разместить несколько экземпляров Redis на одном компьютере, чтобы повысить загрузку процессора, так как они будут конкурировать за один и тот же диск, что приведёт к его перегрузке.

— Отсутствие горизонтальной масштабируемости — это проблема, о которой упоминалось в других ответах.

Иван Терешенко
Иван Терешенко
  • Сообщений: 50
  • Последний визит: 3 декабря 2025 в 00:24

Redis — это хранилище в оперативной памяти, которое также может записывать данные обратно на диск. Вы можете указать, сколько раз выполнять fsync, чтобы сделать Redis более безопасным (но и более медленным => компромисс).

Но все же я не уверен, что redis еще не в состоянии действительно хранить в нем критически важные данные (пока?). Если, например, это не большая проблема, когда появляется еще 1 твит (twitter.com ) или что-то подобное приведет к потерям, тогда я бы обязательно использовал redis. Также много информации о постоянстве доступно на собственном веб-сайте redis.

Вам также следует знать о некоторых проблемах с сохранением данных, которые могут возникнуть при чтении статьи в блоге antirez (разработчиков Redis). Вам стоит почитать его блог, потому что у него есть несколько интересных статей.

DST Global
DST Global
  • Сообщений: 57
  • Последний визит: 12 декабря 2025 в 21:11

Вы можете использовать Redis в качестве авторитетного хранилища несколькими способами:

— Включите AOF (хранилище файлов только для добавления) см. документацию по AOF. Это позволит вести журнал всех команд Redis, выполняемых с вашим набором данных, в режиме реального времени.

— Запускайте Redis с помощью репликации Master-Slave см. документацию по репликации. Это позволит обеспечить высокую доступность в случае сбоя одного из ваших экземпляров.

— Если вы используете что-то вроде EC2, вы можете использовать EBS для резервного копирования раздела Redis, чтобы обеспечить дополнительный уровень защиты от сбоев инстанса.

На горизонте маячит Redis Cluster — это специально разработанная система для запуска Redis, которая должна помочь с высокой доступностью и масштабируемостью. Однако она появится не раньше, чем через полгода.

Иван Терешенко
Иван Терешенко
  • Сообщений: 50
  • Последний визит: 3 декабря 2025 в 00:24

Используем keydb как для кеша, так и хранения горячих данных

В кеше одно ядро, в среднем, обрабатывает 2,5 млн команд в минуту, в среднем, количество обрабатываемых команд колеблется от 2 до 10 млн хз, как redis с таким наплывом справится.

Сколько читаю подобные статьи, никто не пишет то, что висит в воздухе:

— если используется хранение данных, то, при перезагрузке редиса/кейдб, ему надо время, чтобы загрузить данные в память и чем больше данных, тем дольше редис отбрасывает коннекты к базе, например, rdb-файл размером 30Гб, будет грузится около 15 минут и все это время редис работать НЕ БУДЕТ, имейте это ввиду, чтобы потом не оказалось, что у вас сайт на 15 минут упал, потому, что кто-то решил редис дернуть.

— касаемо aof помните, это файл ЖУРНАЛА, т.е. туда пишется КАЖДАЯ команда и если вы не включили перезапись файла, то будьте готовы к тому, что у вас закончится место на диске спустя очень короткое время, если будет большая активность.

— если используете хранение данных, следите за местом. вам надо иметь запас минимум x2 от текущего размера данных в памяти иначе, в момент форка (неважно rdb или aof) у вас закончится место на диске, потому как в этот момент создается temp файл, куда скидываются данные и только после этого удаляется старый файл.

Артем Матвеев
Артем Матвеев
  • Сообщений: 21
  • Последний визит: 1 декабря 2025 в 16:11

Почему бы не использовать и RDB, и AOF? А также что насчет создания форков?

Евгений Абрамов

Можно скомбинировать AOF и RDB в одном и том же экземпляре Redis. Если надёжность хранения данных в обмен на некоторое снижение скорости вас устраивает — можно так и поступить. Полагаю, что это — приемлемый способ использования Redis. Но при этом, если система будет перезагружена, помните о том, что для восстановления данных Redis будет использовать AOF, так как в этом хранилище находится более полная версия данных.

Создание форков процессов Redis

Теперь, когда мы разобрались с механизмами организации постоянного хранения данных в Redis, поговорим о том, как это делается в однопоточном приложении наподобие Redis.

Создание форка процесса Redis. Снепшот содержит данные, актуальные на определённый момент времени. После создания форка данные копируются на диск.

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

Форк — это когда операционная система, по команде, вызванной неким процессом, создаёт новый процесс, копируя родительский процесс. В результате в нашем распоряжении оказывается новый ID процесса и ещё некоторые полезные сведения. При этом только что созданный форк процесса (процесс-потомок) может взаимодействовать с процессом-родителем.

А вот теперь начинается самое интересное. Redis — это процесс, которому выделено огромное количество памяти. Как скопировать такой процесс и не столкнуться с нехваткой памяти?

Когда создают форк процесса — процесс-родитель и процесс-потомок используют память совместно. Redis начинает процесс создания снепшота в процессе-потомке. Это возможно благодаря технике совместного использования памяти, называемой «копирование при записи». При этом во время создания форка память не выделяется, используются ссылки на уже выделенную память. Если, во время сброса данных дочерним процессом на диск, ничего в памяти не менялось, новая память выделяться не будет.

В том случае, если изменения были, происходит следующее. Ядро операционной системы отслеживает ссылки на каждую страницу памяти. Если на некую страницу имеется больше одной ссылки — изменения записываются в новые страницы. Процесс-потомок ничего не знает об изменениях, в его распоряжении имеется стабильный снимок памяти. В результате для создания форка процесса используется лишь небольшой объём памяти. Мы можем быстро и эффективно создавать снепшоты, отражающие состояние хранилища на некий момент времени, размеры которых могут достигать многих гигабайтов.

Итоги

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

Евгений Абрамов
Евгений Абрамов
  • Сообщений: 24
  • Последний визит: 28 июля 2025 в 11:43
Почему бы не использовать и RDB, и AOF? А также что насчет создания форков?

Заявка на услуги DST

Наш специалист свяжется с вами, обсудит оптимальную стратегию сотрудничества,
поможет сформировать бизнес требования и рассчитает стоимость услуг.

Адрес

Ижевск, ул. Воткинское шоссе 170 Е.
Региональный оператор Сколково. Технопарк Нобель

8 495 1985800
Заказать звонок

Режим работы: Пн-Пт 10:00-19:00

info@dstglobal.ru

Задать вопрос по почте

Укажите ваше имя
Укажите ваше email
Укажите ваше телефон