Интерфейс программирования приложений сетевого программирования порталов - Portals network programming application programming interface

Интерфейс программирования приложений сетевого программирования порталов
Разработчики)Сандийские национальные лаборатории, Университет Нью-Мексико
Стабильный выпуск
4.0.2[когда? ]
ТипСеть API
Интернет сайтwww.cs.sandia.gov/ Порталы

Порталы это сеть низкого уровня API для высокопроизводительной сети на высокопроизводительные вычисления системы, разработанные Сандийские национальные лаборатории и Университет Нью-Мексико. В настоящее время Portals - это интерфейс сетевого программирования самого низкого уровня в коммерчески успешной линейке суперкомпьютеров XT от Cray.

Обзор

Порталы основаны на концепции элементарных строительных блоков, которые можно комбинировать для поддержки широкого разнообразия семантики сетевого транспорта верхнего уровня. Порталы обеспечивают односторонние операции перемещения данных, но, в отличие от других интерфейсов одностороннего программирования, целью удаленной операции не является виртуальный адрес. Вместо этого конечный пункт назначения в памяти входящего сообщения определяется в получателе путем сравнения содержимого заголовка сообщения с содержимым структур в месте назначения. Эта гибкость позволяет эффективно реализовывать как одностороннюю, так и двустороннюю связь. В частности, порталы нацелены на обеспечение основных операций, необходимых для поддержки высокопроизводительной и масштабируемой реализации Интерфейс передачи сообщений (MPI) стандарт.[1] Он также использовался в качестве начального сетевого транспортного уровня для Блеск файловая система.

Ранние годы

Порталы были созданы в начале 1990-х как расширение nX система передачи сообщений, используемая в САНМОС и Пума Операционная система. Впервые он был реализован для Intel Paragon в Sandia, а позже перенесен на Intel TeraFLOPS машина названа ASCI Красный.[1]В первой версии Portals было четыре строительных блока: одиночный блок, динамический блок, независимый блок и комбинированный блок. Все входящие сообщения сначала проходят через список соответствия, который позволяет отдельным порталам отвечать на определенные группы, ранги и набор заданных пользователем битов соответствия.[1]

Порталы 3

Концепция порталов продолжала развиваться в течение последовательных поколений легких ядер и систем с массовым параллелизмом. В 1999 году порталы получили интерфейс оперативного программирования, чтобы его можно было реализовать для интеллектуальных или программируемых сетевых интерфейсов вне среды облегченного ядра.[2] Этот стандарт был разработан для систем, в которых работа, необходимая для подготовки, передачи и доставки сообщений, длиннее, чем круговой обход структур данных порталов. Например, в современных системах в этой работе преобладает двусторонний переход через шину ввода-вывода к сетевому интерфейсу. Стандарт был пересмотрен с момента первого выпуска, чтобы сделать его более подходящим для современных высокопроизводительных компьютеров с массовым параллелизмом.[3]Библиотека MPI была перенесена из переименованный Порталы 2 в новые Порталы 3.0.[4]

Спецификация Portals 3 реализовывалась несколько раз, сначала ASCI Красный, Затем на CPlant над Myrinet,[5] Linux и Cray XT семья.[6]

Порталы 4

В свете появления разделенное глобальное адресное пространство (PGAS), несколько новых функций были добавлены в Portals API как часть Portals 4. Portals 4 также внесли несколько изменений для улучшения взаимодействия между процессором и сетевым интерфейсом (NIC) для реализаций, обеспечивающих разгрузку. Наконец, в Portals 4 была добавлена ​​возможность поддержки формы управления потоком.[7]

Portals 4 - это низкоуровневый сетевой API для сетевой карты Bull-Atos BXI.[8]

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

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

  1. ^ а б c Рон Брайтвелл; и другие. (Июнь 1996 г.). Дизайн и реализация MPI на порталах Puma. Конференция разработчиков MPI, 1996. Труды, второе. CiteSeerX  10.1.1.54.3830.
  2. ^ Рон Брайтвелл; и другие. (Декабрь 1999 г.). «Версия 1.0 интерфейса передачи сообщений Portals 3.0». Сандийские национальные лаборатории. Цитировать журнал требует | журнал = (помощь)
  3. ^ Рольф Ризен; и другие. (Апрель 2006 г.). "Версия 2.1 документа интерфейса передачи сообщений Portals 3.3" (PDF). Сандийские национальные лаборатории. Архивировано из оригинал (PDF) на 2011-06-05. Получено 2009-10-02. Цитировать журнал требует | журнал = (помощь)
  4. ^ «Дизайн и реализация MPI на порталах 3.0». Конспект лекций по информатике. Springer. 2002 г.
  5. ^ Нил Пандит. «CPlant: крупнейший кластер Linux». Технический комитет IEEE по масштабируемым вычислениям. Получено 2009-10-02. Цитировать журнал требует | журнал = (помощь)
  6. ^ Кевин Педретти; и другие. (2005-09-27). «Внедрение и производительность Portals 3.3 на Cray XT3». Международная конференция IEEE по кластерным вычислениям. Цитировать журнал требует | журнал = (помощь)
  7. ^ Райан Грант; и другие. (2014-10-01). "Интерфейс передачи сообщений Portals 4.0.2" (PDF). Сандийские национальные лаборатории. Получено 2016-03-25. Цитировать журнал требует | журнал = (помощь)
  8. ^ Derradji, S .; Palfer-Sollier, T .; Panziera, J.P .; Poudes, A .; Велленрайтер, Ф. (26 августа 2015 г.). «Архитектура межсоединений BXI». Симпозиум по горячим межсоединениям. IEEE. Дои:10.1109 / HOTI.2015.15.