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

特集コンテンツ一覧

Agile Japan 2009

2009年4月22日、東京千代田区にある放送会館で「アジャイルジャパン2009」が開催されました。本イベントは「ソフトウェア開発の次世代リーダーをつくる」ことを合い言葉に、200人以上の参加者を集めてスタートしました。

Flex 4の新機能トップ10

今週(2009年6月1日)AdobeはFlex 4の正式な初ベータ版をリリースしました。Flex 4はGumboというコードネームで開発されています。今回のリリースには大きな変更が多数含まれています。このRIAフレームワークの最新バージョンにおいて変更された事柄についての概要を以下のリストで見ていきましょう。

Domain Driven Design(ドメイン駆動設計) Quickly 日本語版

ビジネス領域の深い理解を反映したドメインモデルを設計するための、ヴィジョンとアプローチです。この本は、Eric Evans氏の「Domain Driven Design」の主要点を短く読みやすく要約しました。

JavaプログラマがFlexとBlazeDSを学んだ方がいい13の理由

この記事ではJavaプログラマがなぜFlexとBlazeDSを学ぶべきなのかについて13の理由を述べています。なぜ高度にインタラクティブなWeb サイトからJavaで開発されたバックエンドをもつエンタープライズ・アプリケーションまでを含む、リッチ・インターネット・アプリケーション(RIA)の開発にFlexとBlazeDSの組み合わせが最適な選択肢となるのかについて述べています。

仮想パネル: バックログは重要な成果物とプラクティスか、それとも無駄か?

Mary Poppendieck氏、Ron Jeffries氏、Jeff Patton氏、David West氏、Steve Freeman氏、Jason Yip氏が、バックログに関する彼らの意見とアジャイルチームを成功させるために必要な事を語った。

Perf4Jを使ったパフォーマンス解析とモニタリング

この記事ではAlex Devine氏が、Java開発者がPerf4Jをどのように利用できるかと、タイミングステートメントにコードを追加し、ロギング、結果の解析とモニタリングを行うオープンソースツールセットの説明をします。

複雑な外部DSLを開発する

本稿では、Vaughn Vernon氏が内部DSLと外部DSLの違いを説明し、複雑な外部DSLを開発する際のステップを示します。

J2EEアプリケーションにおけるAOPを使ったフェッチ戦略の実装

この記事では低レベルのサービス・レイヤやリポジトリ・レイヤを肥大化させることなく、フェッチング・ストラテジによってモジュール化された方法でバックエンドにあるシステムからデータを取得する処理を最適化する方法について説明します。