Кэширование AppFabric - AppFabric Caching

Кэширование AppFabric предоставляет в памяти, распределенный кеш платформа для Windows Server.[1] Microsoft разработал AppFabric Caching и выпустил его как часть AppFabric.

Архитектура

Кэширующие магазины AppFabric сериализованный удалось объекты в кеш-кластере. Кластер кеша состоит из одной или нескольких машин, которые объединяют доступную физическую память.[2] Эта объединенная память предоставляется клиентам кэширования как единственный источник кэширующей памяти. Объекты хранятся и доступны с использованием связанного значения ключа.

Функции кэширования AppFabric должны быть установлены на каждом сервере в кластере кэша.[3] После установки необходимо использовать мастер настройки AppFabric для присоединения каждого сервера к кластеру кеша.[4] Внешний файловый ресурс или база данных необходимы для поддержания параметров конфигурации кластера кеша.[5] Набор Windows PowerShell Команды для кэширования предоставляют возможности администрирования кеш-кластера.[6]

Примеры кода

Обратите внимание, что образцы кода в этом разделе показаны в C #.

Распространенной задачей является создание кода, который помещает, извлекает и удаляет объекты из кеша. Эти операции нацелены либо на кеш по умолчанию, либо на именованный кеш.[7]

Сначала создайте статический DataCache[8] член:

общественный статический DataCache _cache;

Затем создайте метод, который обращается к этому кешу. Свойства кеша можно сохранить в файлах app.config или web.config.[9] Параметры кэша также можно настроить программно.[10] В следующем примере показано, как программно настроить кеш.

общественный статический DataCache GetCache(){    если (_cache != ноль)        возвращаться _cache;     // Определить массив для 1 кеш-хоста    Список<DataCacheServerEndpoint> серверы = новый Список<DataCacheServerEndpoint>(1);     // Указываем детали хоста кеша    // Параметр 1 = имя хоста    // Параметр 2 = номер порта кеширования    серверы.Добавлять(новый DataCacheServerEndpoint("моя машина", 22233));     // Создаем конфигурацию кеша    DataCacheFactoryConfiguration конфигурация = новый DataCacheFactoryConfiguration();           // Устанавливаем хост (ы) кеша    конфигурация.Серверы = серверы;           // Устанавливаем свойства по умолчанию для локального кеша (локальный кеш отключен)    конфигурация.LocalCacheProperties = новый DataCacheLocalCacheProperties();     // Отключить трассировку, чтобы избежать информационных / подробных сообщений на веб-странице    DataCacheClientLogManager.ChangeLogLevel(Система.Диагностика.TraceLevel.Выключенный);     // Передаем настройки конфигурации в конструктор cacheFactory    _фабрика = новый DataCacheFactory(конфигурация);     // Получить ссылку на именованный кеш с именем "default"    _cache = _фабрика.GetCache("дефолт");           возвращаться _cache;}

Следующий метод показывает, как использовать _cache объект для извлечения данных из кеша. В этом примере идентификатор пользователя (ID пользователя) является ключом для связанного информационного объекта пользователя. Код сначала пытается получить эту информацию о пользователе из кеша с помощью ID пользователя ключ. Если это не удается, код извлекает информацию с помощью запроса к базе данных, а затем сохраняет возвращенные данные пользователя в кеше. При следующем запуске того же кода информация о пользователе будет возвращена из кеша, а не из базы данных. Это предполагает, что срок действия кэшированных данных не истек или они не были удалены.

тип данных GetUserData(нить ID пользователя) {    тип данных данные = ноль;    // Попытка получить данные пользователя из кеша:    объект dataObject = _cache.Получать(ID пользователя);    если (dataObject != ноль)        данные = (тип данных)dataObject;    еще    {        // Если его нет в кеше, извлечь его из базы данных:        данные = GetUserDataFromDatabase("ВЫБРАТЬ * ИЗ пользователей, ГДЕ userid = @userId", ID пользователя);        // Помещаем возвращенные данные в кеш для будущих запросов:        _cache.Добавлять(ID пользователя, данные);    }    возвращаться данные;}

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

пустота UpdateUserData(нить ID пользователя, тип данных данные) {    // Обновляем информацию о пользователе в базе данных:    результат = UpdateUserDataInDatabase(ID пользователя, данные);        если (результат)     {        // В случае успешного обновления обновляем кеш:        _cache.Положить(ID пользователя, данные);    }}

Следующий вызов удаляет элемент из кеша.

_cache.Удалять(ID пользователя);

История

Изначально у AppFabric Caching было несколько бета-версий под кодовое название Скорость.[11] В июне 2010 г. Microsoft официально выпущен AppFabric Caching как часть AppFabric.[12] Более подробную информацию см. В раздел истории из AppFabric страница.

Связанные технологии кеширования

Кэширование AppFabric связано с другими технологиями кэширования Microsoft. Эти технологии имеют схожие функции, такие как имя сборки, пространство имен и типы.[13] Однако есть некоторые отличия. В таблице ниже описаны эти технологии.

Технология кешированияЦельУстановленоОписание
Кэширование AppFabricНа территорииAppFabricРаспределенный локальный кеш, который использует серверы, которые пользователь подготавливает и управляет.
Кэширование Windows AzureОблакоПакет SDK для Windows AzureКэширование распределяется между экземплярами одной роли в развертывании облачной службы Windows Azure.
Общее кэширование Windows AzureОблакоПакет SDK для Windows AzureКэширование предоставляется в виде многопользовательской службы для использования облачными службами Windows Azure.

Рекомендации

  1. ^ «Возможности кэширования AppFabric 1.1». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
  2. ^ «Схема физической архитектуры кэширования AppFabric». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
  3. ^ «Установка и настройка AppFabric». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
  4. ^ «Настроить AppFabric». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
  5. ^ «Параметры хранилища конфигурации кластера». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
  6. ^ «Использование Windows PowerShell для управления функциями кэширования AppFabric 1.1». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
  7. ^ «Схема логической архитектуры кэширования AppFabric». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
  8. ^ «Класс DataCache». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
  9. ^ «Конфигурация клиента на основе XML». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
  10. ^ «Программная настройка клиента». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
  11. ^ «Создавайте лучшие приложения, управляемые данными, с помощью распределенного кэширования». Журнал MSDN. Microsoft. Получено 13 февраля 2013.
  12. ^ «Microsoft предоставляет релиз-кандидат Windows Server AppFabric, бета-версию BizTalk Server 2010». Центр новостей Microsoft. Microsoft. Получено 13 февраля 2013.
  13. ^ «Различия между кешированием в локальной среде и в облаке». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.

внешняя ссылка