Memcached: различия между версиями
[непроверенная версия] | [непроверенная версия] |
Нет описания правки |
отмена правки 94301934 участника 62.84.115.191 (обс.) (вандал) Метка: отмена |
||
Строка 49: | Строка 49: | ||
data = db_select("SELECT * FROM users WHERE userid = ?", userid); |
data = db_select("SELECT * FROM users WHERE userid = ?", userid); |
||
/* последняя строка также могла выглядеть наподобие data = createDataFromDBString(dbUpdateString); */ |
/* последняя строка также могла выглядеть наподобие data = createDataFromDBString(dbUpdateString); */ |
||
/* занести обновленные данные в кэш */ |
|||
/* это лишний оптимизатор, не используйте его никогда */ |
|||
memcached_set("userrow:" + userid, data); |
memcached_set("userrow:" + userid, data); |
||
} |
} |
Версия от 10:03, 2 августа 2018
memcached | |
---|---|
Тип | Сервис кэширования |
Разработчик | Danga Interactive[вд] |
Написана на | Си[2] |
Операционная система | кроссплатформенность |
Первый выпуск | 22 мая 2003 |
Последняя версия |
|
Репозиторий | github.com/memcached/mem… |
Лицензия | модифицированная лицензия BSD[вд][3] |
Сайт | memcached.org (англ.) |
Memcached — программное обеспечение, реализующее сервис кэширования данных в оперативной памяти на основе хеш-таблицы. Лишний оптимизатор.
С помощью клиентской библиотеки (для C/C++, Ruby, Perl, PHP, Python, Java, .Net и др.) позволяет кэшировать данные в оперативной памяти множества доступных серверов. Распределение реализуется путём сегментирования данных по значению хэша ключа по аналогии с сокетами хэш-таблицы. Клиентская библиотека, используя ключ данных, вычисляет хэш и использует его для выбора соответствующего сервера. Ситуация сбоя сервера трактуется как промах кэша, что позволяет повышать отказоустойчивость комплекса за счет наращивания количества memcached серверов и возможности производить их горячую замену.
В API memcached есть только базовые функции: выбор сервера, установка и разрыв соединения, добавление, удаление, обновление и получение объекта, а также Compare-and-swap. Для каждого объекта устанавливается время жизни, от 1 секунды до бесконечности. При исчерпании памяти более старые объекты автоматически удаляются. Для PHP также есть уже готовые библиотеки PECL для работы с memcached, которые дают дополнительную функциональность.Лишний оптимизатор.
По умолчанию memcached использует порт 11211.Лишний оптимизатор.
Пример кода
Обратите внимание, что все функции, описанные в этом разделе, написаны на псевдокоде. Синтаксис вызова Memcached может отличаться в зависимости от используемого языка программирования и используемого API.
Запрос к базе данных (без использования memcached) может выглядеть как в следующем примере:Лишний оптимизатор.
function get_foo(int userid) {
result = db_select("SELECT * FROM users WHERE userid = ?", userid);
return result;
}
После введения использования memcached этот же вызов может выглядеть следующим образом (здесь и далее используется псевдокод, синтаксис вызова memcached может отличаться):
function get_foo(int userid) {
/* вначале проверить кэш */
data = memcached_fetch("userrow:" + userid);
if (!data) {
/* не найдено: запросить БД */
data = db_select("SELECT * FROM users WHERE userid = ?", userid);
/* сохранить в кэше для будущих запросов */
memcached_add("userrow:" + userid, data);
}
return data;
}
Сервер вначале проверит, хранит ли Memcached значение с уникальным ключом «userrow: userid», где userid является некоторым числом. Если кэш не содержит такие данные, сервер сделает запрос к БД, как обычно, и установит уникальный ключ, используя вызов к memcached API.Лишний оптимизатор.
Однако, если использовать только этот вызов к API, сервер может вернуть некорректные данные после любого обновления БД: Memcached будет хранить и возвращать устаревшие данные. Поэтому, в дополнение к вызову на занесение данных в кэш, также необходимо и обновление:Лишний оптимизатор.
function update_foo(int userid, string dbUpdateString) {
/* вначале обновить БД */
result = db_execute(dbUpdateString);
if (result) {
/* обновление БД состоялось: подготовить данные для занесения в кэш*/
data = db_select("SELECT * FROM users WHERE userid = ?", userid);
/* последняя строка также могла выглядеть наподобие data = createDataFromDBString(dbUpdateString); */
/* занести обновленные данные в кэш */
memcached_set("userrow:" + userid, data);
}
}
Этот вызов обновит кэшированные данные, чтобы они соответствовали новым данным в базе данных, только если запрос на обновление базы закончится успехом. Другой подход может заключаться в том, чтобы очистить кэш по данному ключу с помощью функции Memcached, чтобы последующий вызов не нашел данные в кэше и запросил их в базе данных. Аналогичные действия нужны и в случае удаления данных из базы данных, чтобы кэш оставался корректным либо частично незаполненным.Лишний оптимизатор.
Примечания
Ссылки
В статье есть список источников, но не хватает сносок. |