応答を期待せずにメッセージを送信
このシナリオは、Talend ESB、Talend Data Services Platform、Talend MDM Platform、Talend Real-Time Big Data Platform、Talend Data Fabricにのみ適用されます。
このシナリオでは、プロバイダージョブとコンシューマージョブが必要になります。ESB/Web Servicesファミリー下のコンポーネントに基づいて構築されたジョブは、[Repository] (リポジトリー)の[Services] (サービス)ノードで定義されたWebサービスの実装として機能します。
- [Repository] (リポジトリー)ツリービューで、[Services] (サービス)ノードを右クリックして、コンテキストメニューから[Create Service] (サービスを作成)を選択します。
- ポップアップウィザードで[Name] (名前)フィールドにServiceRequestと入力し、[Next] (次へ)をクリックします。
- [Create new WSDL] (WSDLの新規作成)オプションを選択します。
- [Finish] (終了)をクリックし、この作成を確定します。デザインワークスペースでサービスが開かれます。
- WSDLスケルトンでServiceRequestPortポートを右クリックし、[Show properties] (プロパティを表示)を選択します。[Address] (アドレス)フィールドで、サービスを公開するアドレス(http://127.0.0.1.8088/esb/providerなど)を指定します。
- WSDLスケルトンのポートタイプとしてServiceRequestPortTypeをクリックします。この名前をTEST_ProviderJobSoapBindingに変更します。
- WSDLスケルトンの操作としてServiceRequestOperationをクリックします。この名前をinvoke(anyType):anyTypeに変更します。
- WSDLファイルを保存します。[Repository] (リポジトリー)ビューのServicesノードの下に、新しく定義されたWebサービスが表示されます。
- ServicesノードでServiceRequest 0.1を右クリックし、[Import WSDL Schemas] (WSDLスキーマをインポート)を選択します。このオプションにより、[Metadata] (メタデータ) > [File xml] (XMLファイル)の下でWSDLメタデータがサービスからリポジトリーにインポートされるので、サービスや他のコンポーネント間で操作内容を共有できるようになります。
プロバイダージョブは、tESBProviderRequest、tXMLMap、および2つのtLogRowコンポーネントで構成されます。
data:image/s3,"s3://crabby-images/35433/35433d1ddada53782a7588bbe2351b9b07c6af5f" alt=""
-
[Palette] (パレット)からデザインワークスペースに次のコンポーネントをドロップします。tESBProviderRequest、tXMLMap、2つのtLogRow。
-
デザインワークスペースでtESBProviderRequest_1をダブルクリックして、その[Component] (コンポーネント)ビューを表示し、[Basic settings] (基本設定)を設定するために使われます。
data:image/s3,"s3://crabby-images/4eab6/4eab685a3c9e0bd9d2d583596921cf7bde3eabc0" alt=""
-
[Property Type] (プロパティタイプ)リストから[Repository] (リポジトリー)を選択し、[...]ボタンをクリックしてポート名と操作の粒度に合わせてサービスを選択します。
data:image/s3,"s3://crabby-images/3cf14/3cf14cf6c5b6bd23d662700a6591b9740e5f8048" alt=""
-
[OK]をクリックします。
-
[Edit schema] (スキーマを編集)の横にある[...]ボタンをクリックして、tESBProviderRequest_1のスキーマを表示します。
data:image/s3,"s3://crabby-images/da3a5/da3a5964a5c9ff22af884e7fc6ee0f44d479d4f1" alt=""
-
[OK]をクリックします。
-
tESBProviderRequest_1をtLogRow_1に接続します。
-
デザインワークスペースでtLogRow_1をダブルクリックして、その[Component] (コンポーネント)ビューを表示し、[Basic settings] (基本設定)を設定するために使われます。
data:image/s3,"s3://crabby-images/5e499/5e499e88845d74f2fe5c51064dbc73ece20ade34" alt=""
-
[Edit schema] (スキーマを編集)の横にある[...]ボタンをクリックして、次のようにスキーマを定義します。
data:image/s3,"s3://crabby-images/90865/90865635e05a1b8b56c92748d8d22c8222fcd7c4" alt=""
-
tLogRow_1をtXMLMap_1に接続します。
-
tXMLMap_1をtLogRow_2に接続し、この行をpayloadという名前にします。
-
デザインワークスペースで、tXMLMap_1をダブルクリックして、[Map Editor] (マップエディター)を開きます。
-
マップエディターの右下にある[+]をクリックして、payloadテーブルに1行を追加し、この行をpayloadという名前にします。
-
このpayload行の[Type] (タイプ)カラムで、[Document] (ドキュメント)をデータ型として選択します。対応するXMLルートは、出力フローを表す右側のトップテーブルに自動的に追加されます。
-
payloadテーブルで、rootを右クリックしてコンテキストメニューを開きます。
-
コンテキストメニューで[Create Sub-Element] (サブエレメントの作成)を選択し、ポップアップダイアログボックスにresponseを入力します。
-
responseノードを右クリックし、コンテキストメニューで[As loop element] (ループエレメントとして)を選択します。
-
この操作を繰り返して入力テーブルのrootノードのサブエレメントrequestを作成し、requestノードをループエレメントとして設定します。
-
入力テーブルのrequestノードをクリックし、出力テーブルのresponseノードの行の[Expression] (式)カラムにドロップします。
data:image/s3,"s3://crabby-images/41cfe/41cfe1eba18407edb8e48a6b9ef807c726cb471b" alt=""
-
[OK]をクリックしてマッピングを検証し、マップエディターを閉じます。
-
デザインワークスペースでtLogRow_2をダブルクリックして、その[Component] (コンポーネント)ビューを表示し、[Basic settings] (基本設定)を設定するために使われます。
data:image/s3,"s3://crabby-images/fb94d/fb94d085794ae6c5acd62108c9c49f56cace58c4" alt=""
-
[Edit Schema] (スキーマを編集)の横にある[...]ボタンをクリックして、次のようにスキーマを定義します。
data:image/s3,"s3://crabby-images/9400b/9400b32b6a73258ceab01e7a48d61bc4eeaaecf2" alt=""
-
ジョブを保存します。
コンシューマージョブは、tFixedFlowInput、tXMLMap、tESBConsumer、2つのtLogRow コンポーネントで構成されます。
data:image/s3,"s3://crabby-images/6252f/6252f7b6001644c6e9f072530db92d41043dccf1" alt=""
-
[Palette] (パレット)からデザインワークスペースに次のコンポーネントをドロップします。tFixedFlowInput、tXMLMap、tESBConsumer、2つのtLogRow。
-
デザインワークスペースでtFixedFlowInput_1をダブルクリックして、その[Component] (コンポーネント)ビューを表示し、[Basic settings] (基本設定)を設定するために使われます。
data:image/s3,"s3://crabby-images/849ac/849acf6bb8757bae6e2ef10d2c29fe446bb21d89" alt=""
-
tFixedFlowInput_1コンポーネントのスキーマを編集します。
data:image/s3,"s3://crabby-images/4bd1e/4bd1e12d8d825ab0355f40d982b1315ef35016ed" alt=""
-
[+]ボタンをクリックしてString型の行を新規追加して、payloadStringという名前を付けます。
-
[OK]をクリックします。
-
[Number of rows] (行数)フィールドに行数1を設定するために使われます。
-
[Mode] (モード)エリアで、[Use Single Table] (単一テーブルを使用)を選択し、[Value] (値)フィールドにworldを引用符付きで入力します。
-
tFixedFlowInput_1をtXMLMap_1に接続します。
-
tXMLMap_1をtESBConsumer_1に接続し、この行をpayloadという名前にします。
-
デザインワークスペースで、tXMLMap_1をダブルクリックして、[Map Editor] (マップエディター)を開きます。
-
出力テーブルで、rootノードを右クリックしてコンテキストメニューを開きます。
-
コンテキストメニューで[Create Sub-Element] (サブエレメントの作成)を選択し、ポップアップダイアログボックスにrequestを入力します。
-
requestノードを右クリックし、コンテキストメニューで[As loop element] (ループエレメントとして)を選択します。
-
入力テーブルのpayloadstringノードをクリックし、出力テーブルのrequestノードの行の[Expression] (式)カラムにドロップします。
data:image/s3,"s3://crabby-images/e678e/e678eb00717087cf6fa7b1a433d12b08ae892a30" alt=""
-
[OK]をクリックしてマッピングを検証し、[Map Editor] (マップエディター)を閉じます。
-
プロバイダージョブを開始します。実行ログには次の情報が表示されます。
... web service [endpoint: http://127.0.0.1:8088/esb/provider] published ...
-
tESBConsumer_1[Component] (コンポーネント)ビューで、[Basic settings] (基本設定)を設定するために使われます。
data:image/s3,"s3://crabby-images/a9de0/a9de0bd93a281ad71dabfbb6d63cba20af857282" alt=""
-
[Service Configuration] (サービス設定)フィールドの横にある[...]ボタンをクリックして、エディターを開きます。
data:image/s3,"s3://crabby-images/dd31b/dd31b8bc32ebb5b43ec3e27d55e663f8c58d2194" alt=""
-
[WSDL]フィールドで、http://127.0.0.1:8088/esb/provider?WSDLを入力します。
-
更新ボタンをクリックし、ポート名と操作名を取得します。
-
[OK]をクリックします。
-
tESBConsumerの[Basic settings] (基本設定)で、次のように[Input Schema] (スキーマの入力)を設定するために使われます。
data:image/s3,"s3://crabby-images/ff949/ff94981702e6e4b5d5883de7bc018130285fa86f" alt=""
-
[Response Schema] (応答スキーマ)を次のように設定します。
data:image/s3,"s3://crabby-images/80ad7/80ad7b6ef5ab8f0420cc089a6df66899abdf8cc1" alt=""
-
[Fault Schema] (フォールトスキーマ)を次のように設定します。
data:image/s3,"s3://crabby-images/0e94e/0e94e4860caef5ff05728c79159e67b3f3287d22" alt=""
-
tESBConsumer_1をtLogRow_1とtLogRow_2に接続します。
-
デザインワークスペースでtLogRow_1コンポーネントをダブルクリックして、その[Component] (コンポーネント)を表示し、[Basic settings] (基本設定)を設定するために使われます。
data:image/s3,"s3://crabby-images/6d0de/6d0dec1f639648920c8bdf1aa4d6e8772815f74f" alt=""
-
[Edit Schema] (スキーマを編集)の横にある[...]ボタンをクリックして、次のようにスキーマを定義します。
data:image/s3,"s3://crabby-images/4e1d0/4e1d038f6becad4202ac08f001e9119019dda0ad" alt=""
-
ジョブでtLogRow_2をダブルクリックして、その[Component] (コンポーネント)を表示し、[Basic settings] (基本設定)を設定するために使われます。
data:image/s3,"s3://crabby-images/8c909/8c90959b37f692ceef2e8af9a449496ae4f5ca75" alt=""
-
[Edit Schema] (スキーマを編集)の横にある[...]ボタンをクリックして、次のようにスキーマを定義します。
data:image/s3,"s3://crabby-images/f7a06/f7a06425723f9d2a898313fdf14103c93154acb5" alt=""
-
ジョブを保存します。
-
プロバイダージョブを実行します。実行ログには次の情報が表示されます。
INFO: Setting the server's publish address to be http://127.0.0.1:8088/esb/provider
2011-04-21 14:14:36.793:INFO::jetty-7.2.2.v20101205
2011-04-21 14:14:37.856:INFO::Started
SelectChannelConnector@127.0.0.1:8088
web service [endpoint: http://127.0.0.1:8088/esb/provider] published
-
コンシューマージョブを実行します。ジョブの実行ログには次の情報が表示されます。
Starting job CallProvider at 14:15 21/04/2011. [statistics] connecting to socket on port 3942 [statistics] connected TEST_ESBProvider2 TEST_ESBProvider2SoapBingding | [tLogRow_2] payloadString: <request>world</request> {http://talend.org/esb/service/job}TEST_ESBProvider2 {http://talend.org/esb/service/job}TEST_ESBProvider2SoapBinding invoke [tLogRow_1] payload: null [statistics] disconnected Job CallProvider2 ended at 14:16 21/04/2011. [exit code=0]
-
プロバイダーのログにトレースログが表示されます。
web service [endpoint: http://127.0.0.1:8088/esb/provider] published [tLogRow_1] payload: <?xml version="1.0" encoding="UTF-8"?> <request>world</request> ### world [tLogRow_2] content: world [tLogRow_3] payload: <?xml version="1.0" encoding="UTF-8"?> <response xmlns="http://talend.org/esb/service/job">Hello, world!</response> web service [endpoint: http://127.0.0.1:8088/esb/provider] unpublished [statistics] disconnected Job ESBProvider2 ended at 14:16 21/04/2011. [exit code=0]