Временная изоляция виртуальных машин - Temporal isolation among virtual machines

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

Введение в проблему

Одно из ключевых преимуществ использования виртуализация в консолидация серверов, это возможность беспрепятственно «упаковать» несколько недостаточно используемых систем в один физический хост, таким образом достигая лучшего общего использования доступных аппаратных ресурсов. Фактически, целая Операционная система (ОС) вместе с запущенными в ней приложениями можно запускать в виртуальная машина (ВМ) .Однако, когда несколько виртуальных машин одновременно работают на одном физическом хосте, они совместно используют доступные физические ресурсы, в том числе ЦПУ (s), Сетевой адаптер (s), диск (s) и память. Это добавляет уровень непредсказуемости производительности, которую может демонстрировать каждая отдельная виртуальная машина, по сравнению с ожидаемой. Например, виртуальная машина с временным пиком интенсивных вычислений может мешать другим работающим виртуальным машинам, вызывая значительное и нежелательное временное снижение их производительности. В мире вычислений, который смещается в сторону облачные вычисления В парадигмах, где ресурсы (вычисления, хранилище, сети) могут быть удаленно арендованы в виртуализированной форме в соответствии с точными соглашениями об уровне обслуживания, было бы очень желательно, чтобы производительность виртуализированных ресурсов была как можно более стабильной и предсказуемой.

Возможные решения

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

Для ЦП можно использовать правильные методы планирования на уровне гипервизора, чтобы ограничить объем вычислений, которые каждая виртуальная машина может наложить на общий физический ЦП или ядро. Например, на Xen гипервизор, планировщики BVT, Credit-based и S-EDF были предложены для управления распределением вычислительной мощности между конкурирующими виртуальными машинами.[1]Чтобы получить стабильную производительность в виртуализированных приложениях, необходимо использовать конфигурации планировщика, которые трудосберегающий.Также на KVM гипервизор, некоторые предложили использовать стратегии планирования на основе EDF[2]для поддержания стабильной и предсказуемой производительности виртуализированных приложений.[3][4] Наконец, с многоядерный или же мультипроцессор физический хост, каждую виртуальную машину можно развернуть на отдельном процессоре или ядре, чтобы временно изолировать производительность различных виртуальных машин.

Для сети можно использовать формирование трафика методы ограничения объема трафика, который каждая виртуальная машина может наложить на узел. Кроме того, можно установить несколько сетевых адаптеров на одном физическом хосте и настроить уровень виртуализации так, чтобы каждая виртуальная машина могла предоставлять монопольный доступ к каждому из них. Например, это возможно с доменами драйверов гипервизора Xen. Существуют сетевые адаптеры с несколькими очередями, которые поддерживают несколько виртуальных машин на аппаратном уровне, имея отдельные очереди пакетов, связанные с разными размещенными виртуальными машинами (с помощью IP-адресов виртуальных машин), такие как устройства очереди виртуальных машин (VMDq) с помощью Intel.[5] Наконец, планирование ЦП в реальном времени также может использоваться для улучшения временной изоляции сетевого трафика от нескольких виртуальных машин, развернутых на одном ЦП.[6]

При использовании планирования в реальном времени для управления объемом ресурсов ЦП, зарезервированных для каждой виртуальной машины, одна сложная проблема заключается в правильном учете времени ЦП, применимого к общесистемной деятельности. Например, в случае планировщика Xen службы Dom0 и доменов драйверов могут совместно использоваться несколькими виртуальными машинами, обращающимися к ним. Аналогичным образом, в случае гипервизора KVM рабочая нагрузка, налагаемая на ОС хоста из-за обслуживания сетевого трафика для каждой отдельной гостевой ОС, может быть нелегко различимой, поскольку она в основном включает драйверы устройств уровня ядра и сетевую инфраструктуру (на хосте). ОПЕРАЦИОННЫЕ СИСТЕМЫ). Для случая Xen были предложены некоторые методы устранения таких проблем.[7]

По линиям адаптивное бронирование, можно применять стратегии управления с обратной связью для динамической адаптации количества ресурсов, зарезервированных для каждой виртуальной машины, для поддержания стабильной производительности виртуализированного приложения (приложений).[8]Следуя тенденции адаптивности, в тех случаях, когда виртуализированная система не обеспечивает ожидаемых уровней производительности (либо из-за непредвиденных помех других одновременно работающих виртуальных машин, либо из-за плохой стратегии развертывания, которая просто захватила машину с недостаточными аппаратными ресурсами ) можно жить-мигрировать виртуальные машины во время их работы, чтобы разместить их на более мощном (или менее загруженном) физическом хосте.

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

  1. ^ Людмила Черкасова; Дивакер Гупта; Амин Вахдат (3 сентября 2007 г.), «Сравнение трех планировщиков ЦП в Xen» (PDF), Обзор оценки производительности. Том 35, номер 2, получено 30 июн 2010
  2. ^ Фабио Чеккони, Томмазо Кучинотта, Дарио Фаджоли, Джузеппе Липари,Иерархическое резервирование многопроцессорных ЦП для ядра Linux, Материалы 5-го международного семинара по платформам операционных систем для встроенных приложений реального времени (OSPERT 2009), Дублин, Ирландия, июнь 2009 г.
  3. ^ Томмазо Кучинотта, Гаэтано Анастази, Лука Абени,Соблюдение временных ограничений в виртуализированных сервисах, Материалы 2-го международного семинара IEEE по сервис-ориентированной архитектуре и приложениям в реальном времени (RTSOAA 2009), Сиэтл, Вашингтон, июль 2009 г.
  4. ^ Томмазо Кучинотта, Гаэтано Анастази, Лука Абени, Виртуальные машины в реальном времени, Материалы 29-го симпозиума по системам реального времени (RTSS 2008) - рабочая сессия, Барселона, декабрь 2008 г.
  5. ^ Шефали Чинни, Радхакришна Хиремане, Очереди устройств виртуальной машины, Белая книга технологии виртуализации Intel, 2007 г.
  6. ^ Томмазо Кучинотта, Дхаваль Джани, Дарио Фаджоли и Фабио Чеккони, Предоставление гарантий производительности виртуальным машинам с использованием планирования в реальном времени, Материалы 5-го семинара по виртуализации и высокопроизводительным облачным вычислениям (VHPC 2010), Искья (Неаполь), Италия, август 2010 г.
  7. ^ Дивакер Гупта, Люси Черкасова, Роберт Гарднер, Амин Вахдат,Обеспечение изоляции производительности виртуальных машин в Xen, Proceedings of the 7th International Middleware Conference (Middleware 2006), Lecture Notes in Computer Science, Volume 4290/2006, pp 342-362, Мельбурн, Австралия, ноябрь 2006 г.
  8. ^ Рипал Натхуджи; Аман Кансал и Алиреза Гаффархах (апрель 2010 г.), «Q-Clouds: управление эффектами помех производительности для облаков с поддержкой QoS», Proc. 5-й Европейской конференции по компьютерным системам (EuroSys 2010), Париж, Франция