Кэширование AppFabric - AppFabric Caching
Эта статья слишком полагается на Рекомендации к основные источники.Июнь 2017 г.) (Узнайте, как и когда удалить этот шаблон сообщения) ( |
Кэширование 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. |
Рекомендации
- ^ «Возможности кэширования AppFabric 1.1». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
- ^ «Схема физической архитектуры кэширования AppFabric». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
- ^ «Установка и настройка AppFabric». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
- ^ «Настроить AppFabric». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
- ^ «Параметры хранилища конфигурации кластера». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
- ^ «Использование Windows PowerShell для управления функциями кэширования AppFabric 1.1». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
- ^ «Схема логической архитектуры кэширования AppFabric». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
- ^ «Класс DataCache». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
- ^ «Конфигурация клиента на основе XML». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
- ^ «Программная настройка клиента». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.
- ^ «Создавайте лучшие приложения, управляемые данными, с помощью распределенного кэширования». Журнал MSDN. Microsoft. Получено 13 февраля 2013.
- ^ «Microsoft предоставляет релиз-кандидат Windows Server AppFabric, бета-версию BizTalk Server 2010». Центр новостей Microsoft. Microsoft. Получено 13 февраля 2013.
- ^ «Различия между кешированием в локальной среде и в облаке». Библиотека MSDN. Microsoft. Получено 13 февраля 2013.