WikiDer > Ринда (язык программирования Ruby)

Rinda (Ruby programming language)

Ринда это программная библиотека для создания модульных и распределенных совместных сервисов в Рубин с использованием пространство кортежа или же Линда распределенных вычислений парадигма.

На основе исходного кода, первоначально выпущенного для сообщества Ruby Масатоши СЕКИ в 2000 году,[1] Позже Ринда была поглощена ядром Руби. распределенный Ruby (DRb) модуль. Rinda распространяется как часть основной библиотеки Ruby, начиная с Ruby 1.8.

Пример использования

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

Например, следующая программа создает новое пространство кортежей Rinda и инициализирует службу DRb, которая ожидает запросов, поступающих по сети.

требовать 'rinda / tuplespace'URI = "druby: // localhost: 61676"DRb.start_service(URI, Ринда::TupleSpace.новый)DRb.нить.присоединиться

Используя Rinda, другие приложения могут опрашивать пространство кортежей на предмет кортежей, соответствующих определенным критериям.

Например, приведенная ниже программа подключается к службе Rinda и прослушивает любой кортеж, состоящий из арифметического оператора, следующего за двумя числами (например, последовательность "+ 2 4"). Когда такой кортеж обнаруживается, программа вычисляет результат математической операции ( например, преобразование "+ 2 4" в "6") и сохранение его в пространстве кортежей.

требовать 'ринда / ринда'URI = "druby: // localhost: 61676"DRb.start_servicets = Ринда::TupleSpaceProxy.новый(DRbObject.новый(ноль, URI))петля делать  операции, а, б = ts.брать([ % r {^ [- + / *] $}, Числовой, Числовой])  ts.записывать(["результат", а.Отправить(операции, б)])конец

Наконец, приложения Rinda могут добавлять или удалять кортежи из пространства кортежей.

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

требовать 'ринда / ринда'URI = "druby: // localhost: 61676"DRb.start_servicets = Ринда::TupleSpaceProxy.новый(DRbObject.новый(ноль, URI))кортежи = [["*", 2, 2 ], [ "+", 2, 5 ], [ "-", 9, 3 ]]кортежи.каждый делать |т|  ts.записывать(т)  res = ts.брать(["результат", ноль])  ставит "#{res[1]} = #{т[1]}#{т[0]}#{т[2]}"конец

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

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

  1. ^ "Tuplespace". Архив приложений Ruby (RAA). Получено 26 октября 2011.