WikiDer > Ринда (язык программирования Ruby)
Эта статья нужны дополнительные цитаты для проверка. (Апрель 2016 г.) (Узнайте, как и когда удалить этот шаблон сообщения) |
Ринда это программная библиотека для создания модульных и распределенных совместных сервисов в Рубин с использованием пространство кортежа или же Линда распределенных вычислений парадигма.
На основе исходного кода, первоначально выпущенного для сообщества 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]}"конец
внешняя ссылка
Рекомендации
- ^ "Tuplespace". Архив приложений Ruby (RAA). Получено 26 октября 2011.
Этот инструмент для программирования-связанная статья является заглушка. Вы можете помочь Википедии расширяя это. |