Волонтерские вычисления - Volunteer computing

Волонтерские вычисления это тип распределенных вычислений в котором люди жертвуют неиспользованные ресурсы своих компьютеров на исследовательский проект.[1]

Практика, восходящая к середине 1990-х годов, потенциально может сделать существенные вычислительная мощность доступны исследователям по минимальной цене. Обычно программа, запущенная на компьютере добровольца, периодически обращается к исследовательскому приложению, чтобы запросить вакансии и сообщить о результатах. А промежуточное ПО система обычно выступает в роли посредника.

История

Первым проектом добровольных вычислений был Отличный Интернет-поиск Mersenne Prime, который был запущен в январе 1996 года.[2] В 1997 году за ним последовали распределенный.net. В 1997 и 1998 годах в рамках нескольких академических исследовательских проектов были разработаны системы на основе Java для добровольных вычислений; примеры включают Баянихан,[3] Попкорн,[4] Супервеб,[5] и Шарлотта.[6]

Период, термин волонтерские вычисления был придуман Луисом Ф. Г. Сармента, разработчиком Bayanihan. Это также призыв к глобальным усилиям по социальной ответственности, или Корпоративная социальная ответственность как сообщается в Harvard Business Review[7] или используется на форуме ответственных ИТ.[8]

В 1999 г. SETI @ home и Складной @ дома проекты были запущены. Эти проекты получили широкое освещение в СМИ, и каждый из них привлек несколько сотен тысяч волонтеров.

В период с 1998 по 2002 год было создано несколько компаний с бизнес-моделями, основанными на добровольных вычислениях. Примеры включают Народная власть, Пориво, Энтропия, и United Devices.

В 2002 г. Открытая инфраструктура Беркли для сетевых вычислений (BOINC) был основан в Калифорнийском университете в Беркли. Лаборатория космических наук, финансируется Национальным научным фондом. BOINC предоставляет полную систему промежуточного программного обеспечения для добровольных вычислений, включая клиент, клиентский графический интерфейс, систему времени выполнения приложений, серверное программное обеспечение и программное обеспечение, реализующее веб-сайт проекта. Первым проектом на базе BOINC был Predictor @ home на базе Исследовательского института Скриппса, который начал работу в 2004 году. Вскоре после этого SETI @ home и ClimatePrediction.net начал использовать BOINC. В течение следующих нескольких лет был создан ряд новых проектов на основе BOINC, в том числе Rosetta @ home, Эйнштейн @ home, и AQUA @ home. В 2007 году IBM World Community Grid перешла с платформы United Devices на BOINC.[9]

ПО промежуточного слоя

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

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

Большинство этих систем имеют одинаковую базовую структуру: клиентская программа запускается на компьютере добровольца. Он периодически связывается с серверами проекта через Интернет, запрашивая задания и сообщая о результатах выполненных заданий. Эта модель «вытягивания» необходима, потому что многие компьютеры-добровольцы находятся за брандмауэрами, которые не разрешают входящие соединения. Система отслеживает «кредит» каждого пользователя, это числовая мера того, сколько работы компьютеры этого пользователя сделали для проекта.

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

Кроме того, добровольные вычислительные системы должны решать проблемы, связанные с правильностью:

  • Волонтеры безотчетны и по сути анонимны.
  • Некоторые добровольные компьютеры (особенно разогнанные) иногда дают сбой и выдают неверные результаты.
  • Некоторые добровольцы намеренно возвращают неверные результаты или требуют завышенной оценки результатов.

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

Недостатки для участников

  • Повышенное энергопотребление: ЦП обычно потребляет больше электроэнергии, когда он активен, чем когда он простаивает. Кроме того, желание участвовать может привести к тому, что доброволец оставит компьютер включенным на ночь или отключит функции энергосбережения, такие как приостановка. Более того, если компьютер не может должным образом охладиться, дополнительная нагрузка на ЦП добровольца может вызвать его перегрев.
  • Снижение производительности ПК: если приложение для добровольных вычислений запускается во время использования компьютера, это может повлиять на производительность ПК. Это связано с повышенным использованием ЦП, кеш-памяти ЦП, локального хранилища и сетевого подключения. Если ОЗУ является ограничением, это может привести к увеличению пропусков кеш-памяти диска и / или увеличению числа страниц. Вычислительные приложения-добровольцы обычно выполняются с более низким приоритетом планирования ЦП, что помогает уменьшить конкуренцию ЦП.[10]

Эти эффекты могут быть или не быть заметными, и даже если они заметны, волонтер может продолжить участие. Однако повышенное энергопотребление можно до некоторой степени устранить, установив параметр, ограничивающий процентную долю процессора, используемого клиентом, который доступен в некоторых клиентских программах.

Преимущества для исследователей

  • Добровольные вычисления могут предоставить исследователям вычислительную мощность, недоступную другим способом. Примерно 10 петафлопс вычислительной мощности доступны из добровольных вычислительных сетей.
  • Добровольные вычисления часто дешевле, чем другие формы распределенных вычислений.[11]

Важность

Хотя существуют такие проблемы, как отсутствие подотчетности и доверия между участниками и исследователями при реализации проектов, волонтерские вычисления имеют решающее значение, особенно для проектов с ограниченным финансированием.[нужна цитата ]

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

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

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

  1. ^ а б «Волонтерские вычисления - BOINC». boinc.Berkeley.edu. Получено 18 ноября, 2017.
  2. ^ «История GIMPS». Mersenne.org. Отличный поиск чисел Мерсенна в Интернете. Получено 29 декабря, 2013.
  3. ^ Сармента, Л.Ф.Г. (1998). "Баянихан: веб-волонтерские вычисления с использованием Java". Мировые вычисления и их приложения - WWCA'98: Вторая международная конференция Цукуба, Япония, 4–5 марта 1998 г. Труды. Конспект лекций по информатике. 1368. Springer Berlin Heidelberg. С. 444–461. CiteSeerX  10.1.1.37.6643. Дои:10.1007/3-540-64216-1_67. ISBN  978-3-540-64216-9. ISBN  978-3-540-64216-9 (Распечатать) ISBN  978-3-540-69704-6 (онлайн)
  4. ^ О Регев; Ноам Нисан (28 октября 1998 г.). «Рынок POPCORN - онлайн-рынок вычислительных ресурсов». Труды первой международной конференции по информационной и вычислительной экономике (в Чарльстоне, Южная Каролина). Нью-Йорк, штат Нью-Йорк: ACM Press. С. 148–157. Дои:10.1145/288994.289027. ISBN  1-58113-076-7.
  5. ^ Александров, А.Д .; Ibel, M .; Schauser, K.E .; Шейман, К. (1996). «SuperWeb: проблемы исследований в области глобальных вычислений на основе Java». Труды семинара по Java для высокопроизводительного моделирования и моделирования научных и инженерных вычислений. Нью-Йорк: Сиракузский университет.
  6. ^ Baratloo, A .; Караул, М .; Kedem, Z .; Вайкофф, П. (сентябрь 1996 г.). «Шарлотта: метакомпьютинг в Интернете». Материалы 9-й Международной конференции по параллельным и распределенным вычислительным системам.
  7. ^ Майкл Портер; Марк Крамер. «Связь между конкурентным преимуществом и корпоративной социальной ответственностью» (PDF). Гарвардский бизнес-обзор. В архиве (PDF) из оригинала 14 июля 2007 г.. Получено 25 августа, 2007.
  8. ^ "ResponsI.TK". Ответственный IT-форум.
  9. ^ "Объявление о миграции BOINC". 17 августа 2007 г.. Получено 29 декабря, 2013.
  10. ^ Джефф Гасиор (11 ноября 2002 г.). «Измерение влияния Folding @ Home на производительность». Получено 29 декабря, 2013.
  11. ^ http://mescal.imag.fr/membres/derrick.kondo/pubs/kondo_hcw09.pdf

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