OpenSSI - OpenSSI

OpenSSI
OpenSSI-logo.png
Разработчики)Команда OpenSSI[1]
Стабильный выпуск
1.9.3[1] / 1 сентября 2007 г.
Предварительный выпуск
1.9.6[1] / 18 февраля 2010 г.
Операционная системаLinux
ТипПрограммное обеспечение кластера
ЛицензияGPL v2
Интернет сайтopenssi.org Отредактируйте это в Викиданных

OpenSSI является Открытый исходный код односистемный образ кластеризация система. Это позволяет рассматривать совокупность компьютеров как одну большую систему, позволяя приложениям, работающим на любой машине, получать доступ к ресурсам всех машин в кластере.[2][3]

OpenSSI основан на Linux Операционная система и был выпущен как проект с открытым исходным кодом компанией Compaq в 2001.[4]Это заключительный этап длительного процесса развития, уходящего корнями в LOCUS, разработанный в начале 1980-х гг.

Описание

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

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

особенности

Единое технологическое пространство

OpenSSI предоставляет единое пространство процессов - каждый процесс виден с каждого узла и может управляться с любого узла с помощью обычных команд Linux (ps, kill, renice и т. Д.). Виртуальная файловая система Linux / proc показывает все запущенные процессы на всех узлах.

Реализация единого технологического пространства осуществляется с помощью VPROC абстракция изобретена Locus для OSF / 1 AD Операционная система.

Миграция

OpenSSI позволяет переносить запущенные процессы между узлами. Когда запущенные процессы переносятся, они продолжают иметь доступ к любым открытым файлам, объектам IPC или сетевым соединениям.

Процессы могут быть вручную переносится либо процессом, вызывающим специальный OpenSSI мигрировать (2) системным вызовом или записав номер узла в специальный файл в каталоге процессов / proc.

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

Единый корень

OpenSSI предоставляет единый корень для кластера - с любого узла доступны одни и те же файлы и каталоги. OpenSSI использует несколько механизмов для обеспечения единого корня - CFS (кластерная файловая система OpenSSI), файловые системы кластера SAN и параллельное монтирование сетевых файловых систем.

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

CFS

CFS, кластерная файловая система OpenSSI, обеспечивает прозрачный межузловой доступ к базовому настоящий файловая система на одном узле.

CFS - это сложены поверх реальной файловой системы и координирует доступ с разных узлов, используя жетон механизм. Один узел имеет физический доступ к базовой файловой системе и выполняет все операции чтения и записи. В любой момент один узел владеет токен, представляющий часть базового файла, это означает, что эта часть файла находится в кэше узла-владельца. Если другой узел пытается получить доступ к этой части файла, токен украден и содержимое кеша копируется на узел кражи. Реализация OpenSSI CFS очень похожа на ту, что используется HP TruCluster.[5]

CFS также используется для координации доступа к сегментам разделяемой памяти.

CFS может использоваться в отказоустойчивой системе за счет использования подсистем разделяемых дисков (двухпортовый SCSI или SAN ) или с помощью DRBD. Если узел, который в данный момент напрямую обращается к файловой системе, выйдет из строя, то монтирование CFS терпит неудачу к другому узлу, который напрямую подключен к диску, и теперь кластер обращается к файловой системе через этот узел.

Кластерные файловые системы SAN

OpenSSI может использовать SAN на основании кластерные файловые системы для его корня при условии, что они предоставляют POSIX совместимый интерфейс файловой системы. В настоящее время Блеск и GFS были протестированы.[когда? ]

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

NFS

Крепления OpenSSI NFS файловые системы параллельно на каждом узле. Каждый узел обращается к серверу NFS напрямую.

Единое пространство ввода / вывода

OpenSSI обеспечивает доступ в масштабе кластера ко всем устройствам ввода-вывода в системе с некоторыми ограничениями - узел не может смонтировать блочное устройство с другого узла.

В udev диспетчер устройств используется для управления каталогом / dev. Каждый узел запускает свою собственную копию udev для создания соответствующих узлов устройств в подкаталоге / dev, / dev / 1 для узла 1, / dev / 2 для узла 2 и так далее.

Единое пространство IPC

OpenSSI обеспечивает доступ между узлами ко всем стандартным механизмам межпроцессного взаимодействия Linux, Общая память, семафоры, SYSV очереди сообщений, трубы и Доменные сокеты Unix.

Чтобы реализовать общекластерную разделяемую память - распределенная разделяемая память - OpenSSI использует CFS жетон система. В любой момент времени сегмент памяти может быть прочитан одним или несколькими узлами или записан одним узлом. Если узел без доступа на запись к сегменту пытается выполнить запись, то сегмент помечается как нечитаемый на всех других узлах и доступный для записи на текущем узле. Если узел без доступа для чтения пытается прочитать сегмент, то текущее значение копируется с узла, где оно было допустимым, и если оно было доступно для записи, оно помечается как доступное для чтения.

IP-адрес кластера

OpenSSI использует LVS для обеспечения отказоустойчивой балансировки нагрузки IP Сервисы. Входящие сетевые подключения принимаются директор узел, который перенаправляет их на наименее загруженный серверный узел. (Узел может быть и директором, и сервером). В случае отказа узла-директора другой узел-директор берет на себя управление, и система продолжает принимать входящие соединения.

Распределения

Программное обеспечение OpenSSI доступно для различных Дистрибутивы Linux. OpenSSI ядро не зависит от дистрибутива, но зависит от дистрибутива Linux уровень пользователя системы должны быть изменены, например, в этом процесс и запуск системы скрипты.

В настоящее время поддерживаются следующие дистрибутивы:[когда? ]

  1. Fedora Ядро 3
  2. Debian Сержант

Ведется работа по переносу OpenSSI на Debian Etch и Lenny.[6]

История

Истоки OpenSSI восходят к началу 1980-х годов, когда LOCUS распределенная операционная система был разработан в UCLA. Команда, разработавшая LOCUS, сформировала Locus Computing Corporation и произвел различные версии технологии LOCUS под несколькими названиями, что привело к разработке Кластеры UnixWare NonStop продукт на Тандемные компьютеры, которая к тому времени приобрела команду LOCUS и права на технологию. NonStop Clusters for Unixware был коммерциализирован ШОС в качестве дополнения к UnixWare. Когда ШОС перестала продавать NonStop Clusters, бывшую команду Locus, теперь работающую на Compaq (который тем временем приобрел Tandem), перенес код NonStop Clusters на Linux и выпустил его как открытый код. Команда Compaq продолжала разрабатывать систему, которая теперь называется OpenSSI, в течение некоторого времени после HP приобрел Compaq. OpenSSI в настоящее время разрабатывается независимой командой.[когда? ]

Смотрите также

использованная литература

  1. ^ а б c Кластеры OpenSSI (единый образ системы) для Linux, получено 2008-07-07
  2. ^ Ферри, Ричард; Уотсон, Брайан Дж. (1 августа 2003 г.), Журнал Sys Admin> Управление сервером> Знакомство с проектом OpenSSI, получено 2008-07-06
  3. ^ Пфистер, Грегори Ф. (1998), В поисках кластеров, Верхняя Седл-Ривер, Нью-Джерси: Prentice Hall PTR, ISBN  978-0-13-899709-0, OCLC  38300954
  4. ^ Орловский, Андрей (2001-11-14), «Кавалерия Compaq спасает кластеры Linux», Реестр, получено 2008-10-06
  5. ^ Фафрак, Скотт; Лола, Джим А .; Николс, Брэд; Йейтс, Грегори (2003), Справочник по серверу TruCluster, Digital Press, стр. 342–345, ISBN  1-55558-259-1
  6. ^ OpenSSI на Debian Etch, предварительная версия, получено 2008-10-07

внешние ссылки