InfoQ

News

.NET-Java間のWebサービス相互運用性の新たなオプション

作者 Boris Lublinsky , 翻訳者 編集部 投稿日 2008年3月28日 午前6時23分

コミュニティ
.NET,
Java,
SOA
トピック
インターロップ,
Java+.NET
タグ
WCF,
Microsoft,
JMS,
Apache Axis,
Websphere

.NETおよびJava間のWebサービスの相互運用性ということになると、選択肢としてかつてはHTTPを介したSOAPに限られていた。.NET 3.0の導入によって、これはさらに限定された。というのは.NETでのBasicHTTPバインディングのみがJava Webサービスとの直接的な相互運用性を提供するからである。

最近、この分野で2つの新たなオプションが利用可能になった。Javaと.NET間で相互運用可能なWebサービスを構築する際に、WebSphere MQ (WMQ)およびActiveMQトランスポートが利用できる。さらに、.NET向けの信頼できるメッセージングが拡張された。MSMQに加えて、WMQおよびActive MQの両方が.NET Webサービスの信頼できるトランスポートとして使用できる。

WMQソリューション(source)は、IBMのAlphaWorksで 利用可能なWindows Communication Foundation向けのIBM WMQのカスタムチャネルに基づいており、3月14日に新バージョンが掲載された。この製品は、Microsoft提供のビルトインチャネルと同様の方法 で、WMQがWindows Communication Foundation (WCF)フレームワーク(.NET Framework 3で利用可能)内でカスタムチャネルとして使用されることを可能にする。

WMQ v6.0で利用可能なJMS実装を介したSOAPに従って、メッセージがフォーマットされ、WebSphereアプリケーションサーバおよびCICSを含むJMSサービスインフラストラクチャーを介したWebSphere SOAPやWCFでホストされるサービスとアプリケーションが通信できるようにする。

現在の実装は、実際に可能であることを示すもので、この分野における製品の必要条件を理解するのに役立つよう意図されている(ので、実稼働環境での使用には向かない)。この実装を製品化する計画はまだ完結していない。

カスタムチャネルは、Windows Communication Foundationで提供される拡張性フレームワークを使用してビルドされる。それにより、Microsoftで提供されるビルトイントランスポートと 同様の方法で、フレームワークで統合および使用が可能になる。サービスアプリケーションは通常の方法で、新たなカスタムチャネルを使用するように構成する ことが可能である。クライアントアプリケーションはMicrosoft Service Metadata Utility Tool (Svcutil.exe)のような標準ツールで生成される。サービスメタデータの説明は、サービスを実行する(その他のHTTPエンドポイント経由で公 開されている場合)または、WSDL(Web Service Description Language)を使用することで直接発行することができる。

現在の実装は、以下の制限つきでコアメッセージング機能をサポートしている。

  • Duplexチャネルシェイプのサービスインスタンスにつき1つのクライアントのみのサポート
  • DuplexチャネルはWebSphere MQ v6で提供されるSOAP/JMS実装の拡張であり、それ自体はWCFサービスとクライアント間でのみ使用される
  • コアメッセージング機能のみ(たとえば、トランザクションやセキュリティのような拡張機能に対するサポートには未対応)
  • IWMQ v6の既存のSOAP/JMS環境でホストされるSOAP/JMSサービスとの相互運用性(.NETまたはJava/Axisリスナーを使用)は片方向操作に制限される
  • CICSまたはWebSphere Application ServerのSOAP/JMS環境でホストされるSOAP/JMSサービスとの相互運用性は、1つのコントラクトでの片方向操作と要求/応答操作が混在 した操作はサポートしていないので、それぞれのチャネルシェイプで別々のコントラクトを作成する必要がある

Active MQソリューション(source)はJMSのAxisプロバイダー(Java)および「プラグ可能なプロトコル」機能 (.NET)に基づいている。真の.NETカスタムチャネルがさらにカスタムプログラミングを要求するので、それ自体はパッケージされていない。

どちらのソリューションも完全には製品化されていないが、どちらも代替Webサービス相互運用性トランスポートに関する実験において、すばらしい基礎を提供する。

原文はこちらです:http://www.infoq.com/news/2008/03/wmq-activemq-interop

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

特集コンテンツ一覧

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を使ったフェッチ戦略の実装

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

実証済みのアイデアの融合: S#arp Architectureの裏側

この記事では、Web開発における多数の成熟傾向と、クライアントに価値を提供することに対するそれらのメリット、およびS#arp Architecture(最善の手法と技術を活用しようとするASP.NET MVCをベースとしたフレームワーク)内でのそれらの使用について取り上げます。