InfoQ

News

ErlangおよびRubyの総まとめ:Vertebra、Fuzedでのスケーリング、Github

作者 Werner Schuster , 翻訳者 編集部 投稿日 2008年7月18日 午後12時24分

コミュニティ
Ruby,
Architecture
トピック
Ruby on Rails,
メッセージング,
グリッドコンピューティング,
パフォーマンス&スケーラビリティ,
クラウドコンピューティング
タグ
Ruby on Rails,
github,
Erlang,
EC2,
Rails,
AMQP,
git
近ごろ、さまざまな方法でErlangを使用したプロジェクトをRubyチームが開始した。Erlang(参考記事リンク)が使用される3つの方法を見てみることとする。

EngineYard'のVertebra(参考記事)は、RubyおよびErlangの組み合わせに依存している。以前、以下のように取り上げた。
セキュリティ/ディスカバリー機構、状態マシンワークフローシステムおよび分散キー値ストレージシステムは、すべてErlangで記述されている。エー ジェントを記述するためのエージェントフレームワークはすべてruby経由であり、エージェントの実際の機能性はrubyである。
システムはErlangベースのejabberd(リンク)を中心に構築され、ejabberdはXMPP(リンク)でメッセージングを実装する。Erlangで記述される別 のメッセージングサービスはRabbitMQ(リンク)で、ビジネスメッセージングのインターネットプロトコルであるAMQP(リンク)を実装する。

検索エンジンPowerset(リンク)(近ごろMicrosoftがPowersetを買収)(リンク)は、ErlangやRubyを含む多くのテクノロジー(リンク)上にビルドされる。このインフラの一部は、現在Fuzedという名のもとGithub(リンク)で利用可能である。以下は、プロジェクトのReadmeからの抜粋である。
FuzedはErlangベースのクラスタリングシステムであり、複数の単一スレッドプロセス(信頼度は不明)がリモートホストへの要求に応えることがで きるプールになるよう意図されている。このようなリソースは同種である必要がなく、Fuzedは内部的にそれらを同種プールに分割し、ソフトウェアバー ジョンの「ストリームを越える」ことなしに要求に応える。 これはPowersetのインターナルクラスタリングソフトウェアのリリースであり、Railsでの使用に適合しているが、 generic_json_responderで、正確には内部でどのように使用されているのかを確認するとよい。
FuzedはRubyとErlangを接続するライブラリであるErlectricity(RubyForgeプ ロジェクト)(リンク)を活用する。それは、JavaとErlangを接続するJInterface(リンク)ライブラリに似ている。こうしたライブラリはErlangのポー トおよびメッセージングシステム(リンク)にビルドされる。ざっと概要を知るには、Scott Fleckenstein氏のErlectricity入門を読むとよい(リンク)。Scott Chacon氏は、Amazon EC2でFusedを使用した経験について書いた(リンク)

最後に、Tom Preston-Werner氏が取り掛かっているegitd(リンク)についてgithubブログ上で述べた。

過去数週間に渡り、新しく斬新な方法でGitHubを進化させることを可能にする機密のErlangプロジェクトに取り組んできた。そのプロジェクトはegitdと呼ばれ、gitでシップされるストックgitデーモンの代わりである。

原文はこちらです:http://www.infoq.com/news/2008/07/erlang-ruby-roundup

ブックマーク
digg+,
reddit+,
del.icio.us+,
dzone+,
slashdot+
Hatena

特集コンテンツ一覧

アジャイルにおけるプロジェクトマネジャーの役割

この記事では最初に一般的に産業界でのプロジェクトマネージャーの役割について説明し、それから、アジャイルにおけるコーチ/ファシリィテーターの役割にあてはめてみます。

アレグザンダー祭りにて、James.O.Coplienが語るアジャイルとスクラムの源流とは

「パターン」と呼ばれる設計手法をご存知ですか?この建築の分野ではじまった設計の形式知化手法、および、使う人と作る人の対話のプロセスは、私たちソフトウェアの世界に援用されて1995年に「デザインパターン」という書籍で注目を浴びました。さらに、アジャイルと呼ばれる開発手法には、ユーザーといっしょに対話をしながら設計を進める「パターン」の思想が脈々と引き継がれているのです。

仮想パネル:ソフトウェアアーキテクチャの文書化について

この仮想パネルでは、特に、アジャイルソフトウェア開発環境におけるソフトウェアアーキテクチャの文書化について、Len Bass氏、Grady Booch氏、Paulo Merson氏、Eoin Woods氏に話を聞いた。

HTTPSコネクションの最初の数ミリ秒

HTTPSコネクションを確立するとき、一体何が起こっているのだろう。この記事では安全なコネクションを準備するためにクライアントとサーバの間でどのようなデータの交換が行われているのか、バイトレベルまで詳細に分析する。

Modular Java:動的なモジュール化

Modular Javaシリーズの第3弾は、動的なモジュール化、どのようにバンドルのクラスが解決され、どのように生成され、消滅するのか、どのようにお互いに通信するのかについて、議論する。

分散バージョン管理システムの詳細なガイド

分散バージョン管理システムへの関心や採用は増え続けています。この記事では、分散バージョン管理システムのコンセプトを紹介し、git、Mercurial、Bazaarの3つについて詳しく見てみようと思います。

Modular Java:それは何なのか?

ここ数年にわたって、Javaのモジュール化は活発に議論され続けている話題である。いくつかのJSRによってJavaの進化におけるモジュール化の必要性が示されている。モジュール化の意味するところは何で、なぜそれを気にかけるべきなのだろうか?

Modular Java:静的なモジュール化

Modular Javaシリーズの第2弾は、静的なモジュール化、バンドルの作り方、OSGiのエンジンにそれらをインストールする方法、バンドル間の(バージョン付き)依存性の設定のしかたなどについて扱う。