In this article, we will show the following two use cases of how to call a Web service using a tWebserviceInput component
Talend Studio offers a variety of components for calling different types of Web services, such as tWebServiceInput, tWebservice (advanced component based on tWebServiceInput), tSOAP (for SOAP Web services) and tREST (for REST Web services).
This procedure uses the tWebserviceInput component to show how to call a Web service step by step.
If you would like to Enrich your career with a Talend certified professional, then visit Mindmajix - A Global online training platform: “Talend Online Certification Course” . This course will help you to achieve excellence in this domain.
The Country Web service is a public Web service served by WebserviceX.NET, it is available for everyone as long as you are able to access internet. The following operations are supported in this Web service:
In this example, we will call the GetCurrencyByCountry operation in a Talend Job. Click GetCurrencyByCountry operation in the Country Web service page, you can read the SOAP definition of this operation, including request and response declaration. According to the SOAP request and response, we can know that this Web service requires a CountryName as an input parameter and returns a string of GetCurrencyByCountryResult. Next, we will create a Talend Job that passes some country names to the Web service and get the currency data for each country name.
------ Check Out Talend Tutorials ------
Create a demo Job called CallPublicWebService. The Job design is as follows:
We use a tFixedFlowInput_1 to generate some country name that will be pass to tWebserviceInput and be set as the input parameters for calling the Web service, the country names can come from any a data source. In this example, two country names are generated, as seen below:
tFlowToIterate_1 is used to iterate each country name read from the data source. The Use the default (key, value) in global variable box is checked.
The configurations of tWebServiceInput_1 are as below:
Execute the Job to see the following results on the console:
From the result, we can see that this Web service returns a string with XML format, however, in many real situations, we need to extract the value of specified elements such as , from the return string, use a tExtractXMLField after tWebServiceInput to extract fields from the return string.
In order to print also the column name on the console, the Table model is checked on tLogRow_1.
Execute the job and the following result are printed on the console:
Starting job CallPublicWebService at 14:11 28/06/2014.
[statistics] connecting to socket on port 3691
[statistics] connected
.-----------+-----------+--------+------------.
| tLogRow_1 |
|=----------+-----------+--------+-----------=|
|CountryName|CountryCode|Currency|CurrencyCode|
|=----------+-----------+--------+-----------=|
|France |fr |Franc |FRF |
|France |fr |Franc |FRF |
'-----------+-----------+--------+------------'
.-----------+-----------+-------------+------------.
| tLogRow_1 |
|=----------+-----------+-------------+-----------=|
|CountryName|CountryCode|Currency |CurrencyCode|
|=----------+-----------+-------------+-----------=|
|China |cn |Yuan Renminbi|CNY |
|China |cn |Yuan Renminbi|CNY |
'-----------+-----------+-------------+------------'
[statistics] disconnected
Job CallPublicWebService ended at 14:11 28/06/2014. [exit code=0]
We will take another example to describe how to invoke a Web service that is exposed with a Talend Job. In this example, we will use a tWebserviceInput component to call the advanced Web service created in Deploying or exposing a Job as a Web service.
Creating a demo job
Create a demo Job called CallAdvancedWebservice. The Job design is as follows:
tWebserviceInput_1’s schema:
Execute the Job
Execute the Job to see the following results on the console.
Starting job CallWebserviceExample at 16:04 26/06/2014.
[statistics] connecting to socket on port 3811
[statistics] connected
.-------------------+----.
| tLogRow_1 |
|=------------------+---=|
|mydate |name|
|=------------------+---=|
|26-06-2014 16:04:02|Ross|
|26-06-2014 16:04:02|Ross|
|26-06-2014 16:04:02|Ross|
'-------------------+----'
[statistics] disconnected
Job CallWebserviceExample ended at 16:04 26/06/2014. [exit code=0]
Frequently Asked TALEND Interview Questions & Answers
Talend ESB is supplied with the Apache ActiveMQ software for creating message queues and topics. This recipe shows how we can write to and read from an ActiveMQ queue.
Getting ready
First, we’ll need to start ActiveMQ.
How to accomplish it…
The first thing to do is to write a message to a queue.
Writing to the queue
Reading the message from the queue
How it works…
The first subjob wrote an XML message to the queue by the name customerData. We then viewed the customer data in the queue.
The second subjob then read the XML message from the queue, and we were able to see that the message had been removed (dequeued).
There’s more…
The tMomOutput and tMomInput components in this recipe were configured manually and will commit records as soon as they are read and/or written.
Ensuring lossless queues using sessions
In any production system, it is imperative that the data isn’t lost when being read/written to or from a data source/target. This recipe shows how this is achieved when reading and writing to queues using the tMom component.
Getting ready
Open the job jo_cook_ch09_0090_losslesQueues.
How to do it…
In a similar fashion to creating sessions with a database, we will first add ActiveMQ connection that will create the session.
Add the rollback and commit components
Successful run
Failed run
How it works…
We first created a session that allows transaction style processing by defining a tMomConnection component as transacted.
We then ensured that our tMomOutput component is linked to the session by setting the Use existing connection option to true.
When we ran the first time, rows were sent down the flow killjob, so all 10 records are written to the queue when the commit is processed.
Then, the condition in the tMap component is set to mimic a job failure on the eighth record. When we ran the job after the condition was changed, the commit was never processed, so none of the records written to the queue were persisted.
There’s more…
Like the database sessions, the rollback on a queue is automatic if a job fails, so the job only needs to have a tMomCommit component.
The tMomInput component works in the same way as the tMomOutput when using a connection. In that, messages written to the queue will be removed if no commit takes place.
Name | Dates | |
---|---|---|
Talend Training | Sep 21 to Oct 06 | View Details |
Talend Training | Sep 24 to Oct 09 | View Details |
Talend Training | Sep 28 to Oct 13 | View Details |
Talend Training | Oct 01 to Oct 16 | View Details |
Ravindra Savaram is a Technical Lead at Mindmajix.com. His passion lies in writing articles on the most popular IT platforms including Machine learning, DevOps, Data Science, Artificial Intelligence, RPA, Deep Learning, and so on. You can stay up to date on all these technologies by following him on LinkedIn and Twitter.