メタプログラミングを使ってRubyにプロパティを追加する
Werner Schuster氏が、簡単な例を示しながら、Javaのようなプロパティをメタプログラミングを使ってRubyに追加する方法を示します。
- Ruby,
作者 編集部 投稿日 2008年5月6日 午前6時8分
標準的なSOA実装は多数のサービスに依存しています。こうしたサービスを呼び出すにはサービスのロケーション(すなわち、サービスのエンドポイントアドレス)とバインディング(このエンドポイントに到達するためのトランスポートメカニズム)の知識がなければなりません。最も単純なケースでは、実装時にエンドポイントアドレスをハードコード化することが可能です。このアプローチをとると、ソリューションの実装とサービスのロケーションの間に緊密な結合(ロケーション結合)がもたらされます。エンドポイントアドレスを外に出し、コンフィギュレーションファイル.NET内に置くことにより、実装の状態を改善することができます。こうすればコードを全く修正せずに、アドレスを変更できます。しかし、消費者とサービスの数が増えるにつれて(その結果、コンフィギュレーションファイルも増大)、このオプションもスケーラビリティの問題に直面します。
エンドポイントアドレスと呼び出しポリシーに対するサービスクエリの問題を動的に解決することに特化したコンポーネント「サービスレジストリ」に依存することにより、この問題に対する極めて柔軟かつ維持しやすいソリューションがもたらされます。この場合、サービスレジストリには、各ロケーションでの呼び出しに関連したサービスのデプロイメント、ロケーション、ポリシーに関する全情報が含まれています。
サービスレジストリの概念は当初、Webサービスの全体的な構想の一部として導入されたものであり、UDDI(Universal Description, Discovery and Integration)レジストリをサービス消費者と供給者の間の「仲介者」(ブローカー)として定義しました。UDDIの責務は、消費者が必要とする機能性に基づき、サービス制作者の動的な選択を供給することと考えられました。その役割はイエローページの役割に似ていたのです。多数のベンダーや標準化団体から後押しがあったにもかかわらず、サービス仲介者としてのUDDI利用は決して成功しませんでした。今日のUDDI利用法の大多数はサービスWSDLファイルの参照に限定されており、消費者設計時に使われています。
サービスレジストリのさらに実用的な利用法は、たとえばJ2EE実装で広く使われているサービスロケーター・パターン[1]に類似した、サービス名(およびポリシー)に基づいたサービスエンドポイント/バインディングのランタイム検索です。この場合、(消費者)開発時にサービス定義(インタフェース)を利用可能で、レジストリの使用はサービスエンドポイントアドレスと動的バインディングのランタイム導出に限定されています。
本稿では、SOAソリューションの実装を単純化するために利用できるサービスレジストリの.NET実装を説明します。
続きをご覧になりたい方は、以下URLよりアクセスしてください。
http://www.infoq.com/jp/articles/net-service-registry
また、ガバナンスに関する他の記事をご覧になりたい方は、以下URLで表示される一覧からどうぞ。
http://www.infoq.com/jp/Governance
Werner Schuster氏が、簡単な例を示しながら、Javaのようなプロパティをメタプログラミングを使ってRubyに追加する方法を示します。
現在のRIAアーキテクチャにおいて、クライアント/サーバーの通信は重要な位置を占めています。本稿では、James WardとShashank TiwariがアドビによるオープンソースのBlazeDSメッセージングサーバーの世界へ飛び込みます。
ウィルス対策ソフトや情報漏えい防止用のソフトは、いわば影の存在です。ユーザの操作性やGUIを工夫する以上に、いかに目立たない存在となるかにその技術を注ぎ込んでいます。ここでは日立ソフトが開発した「秘文」の事例を紹介します。
Google Chartは、チャートを作成するためのWebサービスです。本稿では、Google Chartのインターフェースと、Rubyコードから簡単にチャートを生成することができるgchartrbライブラリの説明をします。
全二回からなるこの記事では、ダイナミックビジネスアプリケーション(Dynamic Business Applications:DBAs)の開発についての全体的な眺望を、アーキテクチャと方法論の観点から見ていくことになります。我々のゴールは、「ビジネスの変化や、その他に必要とされる変更に対して、いかにして容易に適応できるアプリケーションを構築していくか」を導きだすことです。
本稿では、Adrien Louis氏がESBベースのSOAに対する2つの接続形態についての賛否について説明しています。その2つとは、会社での単一のESB対「部門毎」に相互接続するESBによるシステムです。
誕生から2年を経てCometは「何が出来るのか」という議論から、「いかに実現するか」という議論に関心が移ってきたように見えます。そこで本稿では同じくJavaOneで数多く取り上げられたNetBeans 6.1とGlassFish v3を使いながら、サンプルを交えてCometを解説していく事にします。
この記事では、WSS3とMOSS 2007に難しい設定など一切せず、すぐに利用可能なWebサービスと、Javaと.NETからそのWebサービスを消費する方法に目を向けます。
No comments
返信