Learn how to configure and manage on-premises Integration Servers and create services that
will be accessed through webMethods Cloud. Pass data easily from a Workflow or a Flow service to an on-premises application and get processed data back to the Workflow or Flow service.
Overview
No subtopics in this section
Hybrid connectivity allows you to establish a secure connection between IBM webMethods Integration and your server behind the firewall. As a result, you can consume data from your on-premises applications and use those applications in your Workflow or Flow service. In hybrid integration, an on-premises Integration Server uses a tenant connection to share account and application information with IBM webMethods Integration. Specifically, the tenant connection enables communication between the on-premises Integration Server and the tenant in IBM webMethods Integration.
This section describes how to configure Integration Server as an on-premises server for use with IBM webMethods Integration. It contains information for administrators who configure and manage on-premises Integration Servers and for application developers who want to create services that will be accessed through IBM webMethods Integration.
An on-premises Integration Server is any Integration Server that is configured to share service metadata with IBM webMethods Integration and enables the execution of those services by integrations defined in IBM webMethods Integration. The service metadata uploaded from an on-premises Integration Server provides the accounts and applications required to create integrations in IBM webMethods Integration.
IBM webMethods Integration has environments and each environment has a different endpoint. You can configure one on-premises Integration Server to an environment.
Note
On-premises Integration Server version 10.3 or later with the latest fix will work with IBM webMethods Integration for hybrid connectivity.
A group of services that you share with IBM webMethods Integration is called an application. Applications are created on the on-premises Integration Server and uploaded to IBM webMethods Integration. IBM webMethods Integration can execute any service hosted by an on-premises Integration Server. When you share services in an application, you are sharing the metadata for the service. For Integration Server services, the metadata you share is the service name, service signature, display name, and service comments. Users of IBM webMethods Integration can then create integrations that invoke services defined in the applications.
Size Limit for Hybrid Integration Messages
The maximum size limit of an encoded service output to be transported over Hybrid Integration is 50 MB.
The following encoding limits are enforced:
java.lang.String uses a fixed width encoding of 2 bytes per java.lang.Character. In general, all data types excluding java.lang.Integer and java.lang.Byte are converted to java.lang.String before encoding. For example, a java.lang.String must be less than 25 MB, however, a byte[] must be less than 50 MB.
Each field or value within the Service Output is framed with metadata during encoding, and this is added to the encoded data.
The Service Output being transported is encoded into a single cumulative piece, so consideration for the number of fields and their cumulative sizes are needed.
Using multiple on-premises webMethods Integration Servers to process requests from IBM webMethods Integration
Multiple on-premises Integration Servers can receive and process requests from IBM webMethods Integration. The on-premises Integration Servers can be in a clustered environment (stateful or stateless) or in a non-clustered environment. When multiple Integration Servers are configured to receive and process requests from IBM webMethods Integration, requests are distributed to each Integration Server in a round-robin fashion.
To use multiple on-premises Integration Servers to process requests from IBM webMethods Integration, the following conditions must be true for all the on-premises Integration Servers:
Configuration for IBM webMethods Integration tenants, accounts, and applications are the same across all the Integration Servers.
The packages containing services to be called from IBM webMethods Integration are the same across all Integration Servers. If you change a package on one of the on-premises Integration Servers, you must propagate the changes to the other on-premises Integration Servers.
Accounts and applications must be uploaded once from one of the Integration Servers, that is, you do not need to upload the accounts and applications from every Integration Server.
Accounts must be enabled on all Integration Servers to receive and process incoming requests from IBM webMethods Integration.
Integration Server Administrator
No subtopics in this section
The Integration Server Administrator is an HTML-based utility to administer the webMethods Integration Server. It allows you to monitor server activity, manage user accounts, make performance adjustments, and set operating parameters. You can run the Integration Server Administrator from any browser-equipped workstation on your network. The Integration Server Administrator is a browser-based application that uses services to accomplish its work.
In hybrid integration, an on-premises Integration Server uses a tenant connection to share account and application information with IBM webMethods Integration. Specifically, the tenant connection enables communication between the on-premises Integration Server and the tenant in IBM webMethods Integration.
A tenant alias contains the location and login details needed for the on-premises Integration Server to establish a connection with IBM webMethods Integration. An on-premises Integration Server can have multiple tenant aliases.
Each account on an on-premises Integration Server is associated with one tenant alias. A single tenant alias can be associated with multiple accounts. An on-premises Integration Server contains a pre-defined tenant alias named default. The default
tenant alias can be edited to specify different credentials and a different URL for IBM webMethods Integration. However, the default tenant alias cannot be deleted.
Note that when an on-premises Integration Server is registered as a webMethods Edge Runtime, IBM webMethods Integration creates a tenant alias named EdgeRuntime_EdgeRuntimeName on the
on-premises Integration Server.
The tenant alias specifies the credentials used to listen for requests and the URL for IBM webMethods Integration with which the on-premises Integration Server shares applications and accounts.
To create a tenant alias, open Integration Server Administrator, go to webMethods Cloud > Tenant connections, and click Create Tenant Connection.
Under Settings, enable the tenant, provide a name for the tenant, specify the user name for the user account on IBM webMethods Integration, the password identified in
the user account for the user name, and the URL of IBM webMethods Integration with which to share accounts and applications created on the on-premises Integration Server.
Under Certificate Settings (optional), complete the fields only if you want to set up a two-way SSL communication with IBM webMethods Integration. If you do not configure certificate settings, at a minimum, Integration Server uses one-way SSL communication with IBM webMethods Integration. Integration Server relies on the truststore
information in the JVM truststore to establish a connection. Ensure that the JVM truststore contains the CA certificates needed to establish a connection to IBM webMethods Integration. If the JVM is configured to use a keystore and key alias, then Integration Server attempts to establish two-way SSL with IBM webMethods Integration.
If you click Update Settings, Integration Server connects to IBM webMethods Integration specified in the webMethods Cloud URL and downloads the configuration information that is required to receive any incoming requests.
Note
If you are using hybrid connectivity and when you update the on-premises settings for the first time after the IBM webMethods Integration upgrade, restart the on-premises webMethods Integration Server. After restart, upload the on-premises account to resume hybrid connectivity. This is applicable for all the on-premises Integration Servers connecting to IBM webMethods Integration.
If you have allowed the Cloud Universal Messaging (UM) hostname in the firewall, you have to also allow the new UM hostname along with the old one. For more information on IP addresses, visit the IP Addresses page.
If Software AG has provisioned dedicated UMs for your tenants, and the shared UM queues, if applicable, are imported to the new dedicated UMs, ensure that you update the settings so that hybrid integrations work with the newly provisioned dedicated UMs.
If you change the tenant password, you must update the tenant password in IBM webMethods Integration and in the on-premises Integration Server. If you update the tenant password in IBM webMethods Integration, you must update the tenant information in the on-premises Integration Server that connects to IBM webMethods Integration. You can update the tenant password on the on-premises Integration Server when it is not connected to the tenant on IBM webMethods Integration. When you enable the tenant, Integration Server attempts to establish the tenant connection with the new password. After changing the tenant password on the on-premises Integration Server, you must disable and then re-enable the cloud accounts for the affected on-premises servers. If you have changed the webMethods Cloud URL, disable and then re-enable the accounts that use the tenant alias to ensure that information is sent to and received from the new destination. Further, the pre-defined default tenant alias cannot be deleted. Also, a tenant alias associated with an account cannot be deleted.
At times, Integration Server disables a tenant alias automatically. It will need to be enabled after resolution of the problem that caused the tenant alias to be disabled. For example, when an on-premises Integration Server receives an authorization failure when attempting to connect to IBM webMethods Integration, the on-premises Integration Server does not make repeated attempts to connect to IBM webMethods Integration. Instead, Integration Server disables the tenant alias. This prevents the on-premise Integration Server and other clients from being locked out of the tenant. Disabling a tenant alias does not disable the accounts associated with the alias. An enabled account can still process and respond to service execution requests from IBM webMethods Integration even if the associated tenant alias is disabled. To stop an account from processing requests from IBM webMethods Integration, disable the account.
Updating IBM webMethods Integration Server’s Password
You can update the IBM webMethods Integration Server’s password using one of the following approaches:
Approach 1: Pausing IBM webMethods Integration Flow services
Approach 2: Without pausing IBM webMethods Integration Flow services
Note
Approach 1 is the recommended method.
In both approaches, the on-premises Integration server need not be restarted.
Approach 1: Pausing IBM webMethods Integration Flow services
Software AG recommends using Approach 1 to ensure that the running Flow services do not encounter an error.
Suspend the running IBM webMethods Integration Flow services.
Update the tenant password in IBM webMethods Integration.
Update the on-premises server tenant password (tenant configuration under WmCloud in Integration Server Admin portal) to match with the new IBM webMethods Integration server’s password. This step must be repeated for every affected on-premises server.
Disable and re-enable the cloud accounts for the affected on-premises servers.
Resume IBM webMethods Integration Flow services.
Approach 2: Without pausing IBM webMethods Integration Flow services
You must perform all of these steps immediately before the current running service calls to the on-premises server times out. The default timeout value is 60 seconds. Otherwise, there is a chance that the IBM webMethods Integration Flow services may encounter errors due to service timeout.
Disable the cloud accounts used in IBM webMethods Integration to prevent Flow services from using on-premises services. The accounts are configured in the WmCloud configuration menu for each on-premises server that connects to IBM webMethods Integration.
Update the tenant password in IBM webMethods Integration.
Update the on-premises server tenant password (tenant configuration under WmCloud in Integration Server Admin portal) to match with the new IBM webMethods Integration server’s password. This step must be repeated for every affected on-premises server.
An account specifies the connection parameters needed to access IBM webMethods Integration. Each account on an on-premises Integration Server is associated with a single tenant alias, however, you can choose which tenant alias the account uses.
When you create an on-premises account on the on-premises Integration Server, you specify the connection parameters that the on-premises Integration Server uses to access IBM webMethods Integration. For each account, you specify a tenant alias that communicates with the on-premises Integration Server. Each account can be associated with a different tenant alias. You create accounts on the on-premises Integration Server to allow them to serve any requests that originate from IBM webMethods Integration.
If an account is disabled on the on-premises Integration Server, any requests sent from IBM webMethods Integration will time out depending on the time specified in the Request Timeout field.
The Accounts screen lists all the accounts that reside on your on-premises Integration Server. It also displays whether each account is enabled.
To create an account on an on-premises Integration Server, in the webMethods Cloud menu in Integration Server Administrator, click Accounts > Create On-Premise Account.
Complete the following fields:
Enable: Enables or disables the webMethods Cloud account. When an account is enabled, Integration Server automatically establishes connectivity with IBM webMethods Integration at startup and is ready to serve any requests originating from IBM webMethods Integration. When an account is disabled, the on-premises Integration Server does not use the account to listen for requests from IBM webMethods Integration. Only an enabled account can listen for requests from IBM webMethods Integration to execute services on the on-premises Integration Server. When an account is disabled, requests sent to the on-premises Integration Server remain in the queue until they are read or expire.
Alias Name: A unique name for the account.
Description: Description of the account.
Tenant Alias: The tenant used with the account. The tenant alias specifies the credentials used to connect to IBM webMethods Integration. Disabling a tenant alias does not effectively disable the accounts associated with the alias. An account can still receive, process, and reply to requests for on-premises services from IBM webMethods Integration when the tenant alias associated with the account is disabled. If you changed the webMethods Cloud URL for a tenant alias since the account was uploaded or since
you started Integration Server, you must disable and then re-enable the accounts that use the tenant alias to ensure that information is sent to and received from the new destination.
Stage: The IBM webMethods Integration environment from which the on-premises Integration Server receives requests. The list is populated by the environments defined on IBM webMethods Integration.
Maximum Reconnection Attempts: Specify the maximum number of reconnection attempts that Integration Server should make if the connection to IBM webMethods Integration fails. When the connection between IBM webMethods Integration and on-premises Integration Server is down, Integration Server reconnects to IBM webMethods Integration with a random interval between 100 milliseconds to 10 seconds for the first two minutes and then waits for a period of 30 to 60 seconds before attempting to retry the connection. The on-premises Integration Server continues in this manner until connectivity to IBM webMethods Integration is restored.
Request Timeout: Maximum amount of time (in milliseconds) that IBM webMethods Integration waits for the on-premises Integration Server to process a request. If the on-premises Integration Server is not listening for a request or if it takes longer to process the request than the specified time, IBM webMethods Integration issues an error and stops listening for a response. The default is 60000 milliseconds (1 minute). When the request timeout expires, IBM webMethods Integration shows the exception [ISS.0021.8042E] Error occurred while executing service [on-prem-servicename] with request ID [requestID]. The on-premises Integration Server did not respond within the configured request timeout of [requestTimeoutValue] milliseconds. Check on-premise logs. If the invoked on-premises service takes more time to execute than the Request Timeout value, Integration Server writes the following error message to the serverlog: [ISS.0021.8041E] Error occurred while executing service [serviceName] with request ID [requestID]. Service execution took [x] milliseconds, which is more than the configured request timeout of [y] milliseconds. When responding to a request from IBM webMethods Integration, the on-premises Integration Server adds a time-to-live (TTL) property to the response. The on-premises Integration Server uses the Request Timeout value set for the IBM webMethods Integration account as the TTL value for the response. If the on-premises Integration Server sends the response after the timeout value for the request elapses on IBM webMethods Integration, the response remains on IBM webMethods Integration only until the response expires (that is, only until the TTL in the response elapses).
Time to Live: If you are batching the data from the on-premises Integration Server, this is the length of time in seconds that the execution results remain in the cache of the on-premises Integration Server. The value must be greater than 0. The default is 60 seconds.
Enable Compression: Specify whether on-premise Integration Server and IBM webMethods Integration must compress the request and response payloads during hybrid messaging.
Note
Selecting the Enable Compression checkbox enables compression only if both the on-premise Integration Server and IBM webMethods Integration installations are configured to use the compression functionality. The compression process starts at IBM webMethods Integration. If IBM webMethods Integration compresses the request payload, on-premise Integration Server decompresses, processes, and compresses the payload in the response to IBM webMethods Integration. However, if IBM webMethods Integration does not perform compression, then on-premise Integration Server returns the payload in its original, uncompressed form.
Allowed On-Premise Hosts: The on-premises Integration Server might use multiple addresses, depending on which network or proxy it uses to access IBM webMethods Integration. Specify a comma-separated list of IP addresses that can receive requests from IBM webMethods Integration. Only those IP addresses specified can receive requests.
If no value is specified, IBM webMethods Integration derives the IP address of the on-premises Integration Server that uploads the account to IBM webMethods Integration and allows only that IP address to receive requests from IBM webMethods Integration.
Run As User: Specify the user name you want the on-premises Integration Server to use when running the service. You can select users from the local or central directory. The on-premises Integration Server runs the service as if the user you specify is the authenticated user who invoked the service. If the service is governed by an ACL, ensure that you specify a user who is allowed to invoke the service.
Test Account Settings: Click to test the account settings. Integration Server Administrator displays a status line that indicates whether the account is valid or not. The status line is displayed at the top of the screen.
After creating an account, you can edit the details. The tenant, alias, and stage of an account cannot be changed. If you edit an account, you must upload the account for the changes to take effect on IBM webMethods Integration.
You can upload accounts in two ways, as part of an application, or individually, separate from applications. In order to upload an account as part of an application, you must first create the account and then associate it with the application when you upload it to IBM webMethods Integration.
Upload accounts separately from applications in the event when you need to override the settings of a previously uploaded account. You might do this if you associate an account while uploading an application to IBM webMethods Integration and later change the account details. This way, you can change the account details without having to upload the entire application.
Uploading on-premises accounts to IBM webMethods Integration
After an account is created, you upload it to IBM webMethods Integration so that it can be used to execute services on the on-premises Integration Server. If you change or edit the account after it is uploaded to IBM webMethods Integration, you must upload it again for the changes to become effective. If you want to upload the account as part of an application, use the procedure described in the Uploading Applications section.
To upload accounts to IBM webMethods Integration, in the webMethods Cloud menu in Integration Server Administrator, click Accounts.
Click one of the following icons in the Upload column for the account you want to upload.
Icon
Description
New or has been edited since the last time it was uploaded to IBM webMethods Integration. For a new account, the icon indicates that the account has not been uploaded to IBM webMethods Integration. For an account that already exists on IBM webMethods Integration, the icon indicates that the account on the on-premises Integration Server is not synchronized with the one on IBM webMethods Integration.
Synchronized with the account that has already been uploaded to IBM webMethods Integration.
When you upload the account, Integration Server Administrator displays a status line that indicates whether the account has been uploaded successfully. The status line is displayed at the top of the screen. Integration Server Administrator also updates the Last Uploaded Time field to indicate the time that the account was uploaded and displays the icon to indicate that the account on IBM webMethods Integration is synchronized with the one on the on-premises Integration Server.
If an account gets disabled during an upload, Integration Server uploads the account successfully and notifies you to enable the account to serve any requests originating from IBM webMethods Integration. When accounts are disabled, IBM webMethods Integration cannot execute services on the on-premises Integration Server. After the account is enabled, Integration Server automatically establishes connectivity with IBM webMethods Integration at start up and is ready to serve any requests originating from IBM webMethods Integration. If you have not enabled an account while creating it, you can enable the account by going to Accounts and clicking No to enable the account under the Enabled column.
When you no longer need an account, you can delete it. Deleting an account from the on-premises Integration Server also deletes the account from IBM webMethods Integration if the tenant is enabled. If the account is in use by any of the integrations in IBM webMethods Integration, the delete operation fails. To delete an on-premises account, click Accounts and then click the delete icon.
Monitoring on-premises listeners for accounts
Each enabled webMethods Cloud account should have an active listener on the on-premise Integration Server. The listener listens for requests from IBM webMethods Integration to execute services on the on-premises Integration Server. To ensure that each enabled account has an active listener, Integration Server uses a monitoring thread that executes at a specified interval. If the monitoring thread finds a listener that is not running, the monitoring thread attempts to start the listener. The watt.wmcloud.listeners.monitoringInterval server configuration parameter determines the interval at which the monitoring thread executes. The default value of the parameter is 300000 milliseconds (5 minutes).
Integration Server stops and restarts all on-premises account listeners whenever you click the Update Settings option on the Tenant connections page.
Note
The monitoring thread exists only if the on-premises Integration Server has at least one enabled account.
When an account connection is disconnected or restored, Integration Server notifies the user through a notification in Integration Server Administrator followed by an email. Integration Server generates notifications for an active listener.
When you create an account, the on-premise Integration Server creates two listeners (request and response) for the account. Therefore, if an account is disconnected or reconnected, Integration Server generates two notifications per listener. Configure the hybrid activity notifications using the watt.server.hybridConnectivityAlert.notifications server configuration parameter and the recipients of the notification emails using the watt.server.hybridConnectivityAlert.toMailList server configuration parameter. Integration Server uses the email notification settings configured in Integration Server Administrator > Settings > Resources. For more information, see the webMethods Integration Server Administrator’s Guide.
Configuring sessions for use by accounts
For each account, the on-premises Integration Server maintains a session pool to send responses to the Cloud. Integration Server provides server configuration parameters
to set the pool size and the interval at which Integration Server sweeps for unused sessions. Integration Server starts with a minimum number of sessions for each account. The watt.wmcloud.sessionPool.minCount controls the minimum pool size. When the minimum number of sessions are in use, Integration Server creates new sessions to handle additional
requests. Integration Server continues to create new sessions until it handles all the requests for the account or it reaches the maximum size of the session pool. The
watt.wmcloud.sessionPool.maxCount value determines the maximum size of the session pool for the account. After the session pool reaches the maximum size, Integration Server reuses sessions in a round-robin fashion. As the load reduces, sessions become unused. Integration Server uses a background thread to sweep for and remove unused “extra” sessions. For example, if watt.wmcloud.sessionPool.minCount is set to 3 and an account session pool contains 10 sessions, 7 of those sessions are “extra” or “additional”. If 8 of the 10 sessions are unused, Integration Server removes only 7 of the unused sessions to keep the minimum number of sessions in the pool.
The interval at which the sweeper runs is controlled by the watt.wmcloud.sessionPool.sweeperInterval parameter.
watt.wmcloud.sessionPool.maxCount: The maximum number of sessions in the session pool that is used to send responses to the Cloud.
watt.wmcloud.sessionPool.minCount: The minimum number of sessions in the session pool that is used to send responses to the Cloud.
watt.wmcloud.sessionPool.sweeperInterval: The interval at which Integration Server removes unused sessions in session pools for the accounts. Integration Server
removes only the number of unused sessions in excess of the minimum session pool size.
For more information about these parameters, see the webMethods Integration Server Administrator’s Guide.
A group of services that you share with IBM webMethods Integration is called an application. On-premises applications are created on the on-premises Integration Server and uploaded to IBM webMethods Integration. IBM webMethods Integration executes any service hosted by an on-premises Integration Server.
When you share services in an application, you are sharing the metadata for the service. For Integration Server services, the metadata you share is the service name, service signature, display name, and service comments. You can then create integrations in IBM webMethods Integration that invoke services defined in the applications. When IBM webMethods Integration executes a service, the on-premises Integration Server returns all the results to IBM webMethods Integration. You can batch the results to limit the number of results returned to IBM webMethods Integration.
After you create applications, you upload them to IBM webMethods Integration. If the application changes on the on-premises Integration Server, you must upload the application again for the changes to be replicated on IBM webMethods Integration.
When you upload applications to IBM webMethods Integration, you associate one or more accounts that the application can use to access services on the on-premises Integration Server. If the account associated with an application changes, you can upload the account to IBM webMethods Integration without having to upload the application.
Defining on-premises applications to share with IBM webMethods Integration
To define an on-premises application to share with IBM webMethods Integration, in the webMethods Cloud menu, click Applications > Define webMethods Cloud Application and under webMethods Cloud Application, complete the following fields.
Name: A unique name for the application. The application name cannot exceed 32 characters, contain reserved words and characters that are used in Java or C/C++ (such as for, while, and if), or the following illegal characters: “#-&@^!%*:$./\`;,~+=)(|}{][><”
Description: Description of the application.
Assign Services to Application: Specify the services to expose to IBM webMethods Integration. Under Package/Services, click the + icon to expand the services available in the package. Select each service that you want to expose to IBM webMethods Integration. If you want the service to return results in batches rather than return the results all at once, click Batch Data. If the top level output signature of the service contains only one field, and the field is a document list or document reference list (both of which are IData arrays), Batch Data is selected by default. Otherwise, it will be cleared. Under Display Name, specify the name of the service as it should appear in IBM webMethods Integration or accept the default. The Display Name field cannot contain reserved words and characters that are used in Java or C/C++ (such as for, while, and if) or the following illegal characters: “#-&@^!%*:$./\`;,~+=)(|}{][><”
Note
Applications are displayed in IBM webMethods Integration as on-premises connectors. Operations are named according to the name defined in the Display Name field.
Uploading on-premises applications
After you define an on-premises application, you must upload the application to IBM webMethods Integration before using it. To upload an application, open the Integration Server Administrator and in the webMethods Cloud menu, click Applications.
Click one of the following icons in the row that corresponds to the application you want to upload in the Upload column.
Icon
Description
New or has been edited since the last time it was uploaded to IBM webMethods Integration. For a new application, the icon indicates that the application has not been uploaded to IBM webMethods Integration. For an application that already exists on IBM webMethods Integration, the icon indicates that the application on the on-premises Integration Server is not synchronized with the one on IBM webMethods Integration.
Synchronized with the application that has already been uploaded to IBM webMethods Integration.
When the Upload Application screen appears, in the Select Accounts area, select one or more accounts to associate with the application and then click Upload.
When you upload the on-premises application, the on-premises Integration Server uploads the application to IBM webMethods Integration, replacing the existing on-premises connector. It updates the Last Uploaded Time column of the webMethods Cloud Applications screen to indicate that the on-premises connector on IBM webMethods Integration is synchronized with the one on the on-premises Integration Server. It also shares the service name, service signature, display name, and service comments with IBM webMethods Integration.
If the application has been uploaded earlier, uploading the application again overwrites the existing on-premises connector. Further, if any account associated with an application is disabled during an upload, Integration Server uploads the application successfully and notifies you to enable the account to serve any requests.
Note
Applications uploaded from the on-premises Integration Server are listed in the Connectors > On-Premises Connectors page in IBM webMethods Integration.
When you no longer want to share on-premises applications with IBM webMethods Integration, you can delete them. Deleting an application from the on-premises Integration Server also deletes the application and its corresponding operations from IBM webMethods Integration.
After creating an application, you can edit the application details. If you edit an application, you must upload the application for the changes to take effect on IBM webMethods Integration. The updated application is not available for use until you upload it.
Sharing metadata on an on-premises Integration Server
You can create on-premises applications on the on-premises Integration Server to share services with IBM webMethods Integration.
Points to note while sharing services through an application
You can share only services running on the on-premises Integration Server configured to create applications on IBM webMethods Integration.
You can share only services contained in custom packages.
You can share services from different packages in the same application. For example, if service A is located in package A, and service B is located in package B, you can add both service A and service B to the same application.
You can share only those services whose signatures are of the following data types: String, String List, Document, Document Reference, Document List, Document Reference List, Object, Object List.
You can share only those services that have an input and/or output signature specified.
You can set the on-premises Integration Server to send service results to IBM webMethods Integration in batches.
You cannot share service signatures that include cyclical dependencies of document references, fields of type String Table, including fields of type String Table in a Document, and an empty Document or Document List.
When the server log facility code 0021 webMethods Cloud is set to the Debug log level, Integration Server writes log messages that indicate why an on-premises service is marked as not shareable.
You must configure one or more accounts to associate with the application before you can upload the application to IBM webMethods Integration.
You must upload the application for the updates to be shared with IBM webMethods Integration if you edit either the application or the signature or referenced Document of a service shared by the application.
When you upload an application, it replaces the application and operations available on IBM webMethods Integration with the one that you upload.
Connecting to IBM webMethods Integration through a Proxy
If your on-premises Integration Server is to connect to IBM webMethods Integration through an Internet proxy, you may need to perform additional configurations which fall into the following categories:
Creating a proxy server alias.
Adding proxy-related Java system properties to the Java Virtual Machine in which the on-premises Integration Server runs.
Configuring the Internet proxy for use with the on-premises Integration Server and IBM webMethods Integration.
Creating a Proxy Server Alias
If your company requires the use of a proxy server to establish outbound connections to applications located in the cloud, you need to configure a proxy server alias for your on-premises Integration Server. A proxy server alias identifies the proxy server and the port on the proxy server through which you want to route requests and any credentials needed to access the proxy server.
Configure a proxy server alias using the External Servers > Proxy Servers page in Integration Server Administrator. For detailed information about proxy servers and how to configure a proxy server, see the webMethods Integration Server Administrator’s Guide.
When creating a proxy server alias for use for connection to IBM webMethods Integration, do the following:
Specify the proxy server alias as the default proxy server alias.
Specify the proxy host and port number.
Set the protocol to HTTPS.
If the proxy server is configured for basic authentication, the proxy server alias must specify the user name and password required to access the proxy server.
Updating JVM Configuration Settings for Proxies
Depending on your networking and security requirements, you may need to set Java system properties related to proxy servers. As the connection between the on-premises Integration Server and IBM webMethods Integration is over HTTPS, you need to set some or all of the following:
https.proxyHost
https:proxyPort
http:nonProxyHosts
https.proxyUser
https.proxyPassword
As the proxy property values need to be set for the Java Virtual Machine (JVM) in which Integration Server runs, you update the custom_wrapper.conf file to ensure the proxy parameter values are supplied when the JVM launches.
Specifically, you add a wrapper.java.additional.n property that specifies the property name and value that you want to pass to Integration Server, where n is a unique sequence number. The property name must be preceded by -D.
For example, the wrapper.java.additional properties in the custom_wrapper.conf file might look similar like the following:
For instructions about passing the Java system properties to Integration Server and the JVM used by Integration Server, see the webMethods Integration Server Administrator’s Guide.
To pass system properties to Microservices Runtime, update the JAVA_CUSTOM_OPTS property in Integration Server_directory /bin/server.bat(sh).
For more information about passing system properties to Microservices Runtime, see the Developing Microservices with webMethods Microservices Runtime document.
If Integration Server uses Java SE Development Kit 8, Update 111 or later and the Internet proxy is configured to enforce HTTPS Basic authentication, you may need to add the following system properties to custom_wrapper.conf:
jdk.http.auth.proxying.disabledSchemes
jdk.http.auth.tunneling.disabledSchemes
Configuring the Internet Proxy
When using a proxy server for outbound requests from the on-premises Integration Server to IBM webMethods Integration, you may need to configure the following on the proxy server:
Allowed entries: If the proxy server employs a list of allowed URLs, you need to add the URL for IBM webMethods Integration. A URL for IBM webMethods Integration uses the following format: https://sample.prod-int-aws-us.webmethods.io.
For more information about specifying the allowed entries for an Internet proxy, see the documentation for the Internet proxy used by your company. Click here for information on the IP address categories to allow in IBM webMethods Integration.
Tunneling with HTTP CONNECT: To ensure end-to-end encryption for TLS over HTTPS, configure the Internet proxy to accept the HTTP CONNECT method. If the Internet proxy does not accept the HTTP CONNECT, a connection from the on-premises Integration Server to IBM webMethods Integration through the proxy server can still be established but end-to-end encryption with TLS will not be provided.
Long running HTTP connections: Configure the proxy server to be friendly to long running HTTP 1.0 and 1.1 connections. This may improve performance and limit latency.
The IBM webMethods Integration platform is available on two Cloud Vendors - Amazon Web Services (AWS) and Microsoft Azure. Based on the vendor and the associated region selected by you at the time of creating your IBM webMethods Integration tenant, you need to allow relevant IP addresses to establish the connectivity between IBM webMethods Integration and your on-premises Integration Servers.
For more information about the IP categories allowed and the ports that must be configured for cloud connectivity, see Allowed IPs and ports to open for cloud connectivity under Firewall Friendly IPs.
Locate the region your tenant belongs to and allow the relevant IP addresses.
Note
See the IP Addresses page for information on the list of relevant IP addresses. Once you add these addresses to your firewall, you should be able to connect to your resources from IBM webMethods Integration. If not, contact IBM support with the required details.
Troubleshooting tips for hybrid connectivity
Do the following checks to troubleshoot hybrid connectivity issues:
Check whether you have installed the latest WmCloud fix.
In Integration Server Administrator, go to Settings > Logging > Server Logger > Integration Server and set the webMethods Cloud Log Level to Trace. You can then debug by the specific request ID appearing in IBM webMethods Integration. If you set it to Trace, the Logs > Server page will have detailed information for troubleshooting purposes.
Check if the configurations provided in webMethods Cloud > Settings in Integration Server Administrator are correct.
Verify whether the Account is enabled in webMethods Cloud > Accounts in Integration Server Administrator.
If there are connectivity issues with Accounts, in Integration Server Administrator, go to Settings > Logging > Server Logger > UM Client Logger and set the Log level to Trace. The umClient log file will then show more details on the UM connectivity issues.
Check if the proxy server has been configured correctly. Update the custom_wrapper.conf file and specify the parameters correctly.
If your proxy requires allowing any specific outbound connections, add the parameters in your proxy server while connecting from on-premises to the cloud Load Balancers (LBs) and the Universal Messaging (UM) servers. Contact IBM support to add the UM IPs, UM LB IPs, and LB IPs to allow outbound traffic from on-premises to the cloud. Also open the relevant ports. Click here for more information.
If you have a proxy that uses your own self-signed certificates, add the proxy’s certificate in the configured JVM Truststore or the Truststore you have configured for the JVM. Also check if you have imported the required certificates into your own Truststore.
If you are provided dedicated UMs for your tenants, and the shared UM queues, if applicable are imported to the new dedicated UMs, ensure that you update the settings so that hybrid integrations work with the newly provisioned dedicated UMs.
Example on how to upload an application and use it in a workflow
Create an account on the on-premises Integration Server.
Create the application you want to run on IBM webMethods Integration.
Upload the application on IBM webMethods Integration.
Use the uploaded application in a Workflow.
Log in to the Integration Server instance
Log in to your Integration Server instance, click the webMethods Cloud option listed on the left-side panel, and then click Tenant connections. Enter the following details on the Settings screen. Once this is done, click Update Settings to save the settings.
User Name: Enter the email ID of your IBM webMethods Integration account.
Password: Enter the password of your IBM webMethods Integration account.
webMethods Cloud URL: Enter the complete tenant URL of your IBM webMethods Integration account.
Create an account on the on-premises Integration Server
An account on the on-premises Integration Server acts as a two-way communication channel for data transfer between the on-premises Integration Server and IBM webMethods Integration.
So when you execute the application uploaded on IBM webMethods Integration, it in turn invokes the application instance deployed on the on-premises Integration Server where the actual execution takes place. The output/response of this execution is then sent back to IBM webMethods Integration.
To create a new account, go to webMethods Cloud > Accounts, and click Create On-Premise Account.
On the Create Account configuration screen, enter the following details:
General Settings
Enable: Select Yes to enable the account as soon as you create it.
Alias Name: Provide a suitable name for the account.
Description: Provide a short description for the account.
Stage: Select the relevant stage (Development, Live, Pre-live, Test) where you want to run the exposed applications.
Account Settings
Maximum Reconnection Attempts: Enter the maximum number of times reconnection should be attempted before throwing the error.
Request Timeout: Enter the maximum limit (in milliseconds) for request timeout.
Time to Live: Enter the time (in milliseconds) for which the execution results should remain in the cache of the on-premises Integration Server. This is applicable only if you are batching the data.
Allowed On-Premise Hosts: The on-premises Integration Server can use multiple addresses to access IBM webMethods Integration. You can specify a comma-separated list of IP addresses that can receive requests from IBM webMethods Integration. Only these IP addresses can receive requests.
Run As User: Click on the Search icon and select the relevant user role (Administrator, Default, Developer, Replicator) as per your requirements.
Once this is done, click Test Account Settings. This will verify whether the details entered by you are valid or not. If the entered details are valid, you will get a notification message stating so. Click on Save Changes to save the account settings.
Create the application you want to run on IBM webMethods Integration
You need to create the applications you want to execute using IBM webMethods Integration on the Integration Server. Once created, these applications can then be uploaded to IBM webMethods Integration where they can be used in the workflows and Flow services.
To create an application, go to webMethods Cloud > Applications and click Define webMethods Cloud Application.
In the Define Application configuration window, enter the following details:
Name: Provide a suitable name for the application. This name will be visible to you as the application name in the Connectors panel of your IBM webMethods Integration account. Spaces are not allowed in the application name. You can replace the spaces with underscores instead. For example, my_application.
Description: Provide a short description for the application.
Assign Services to Application: Select the relevant services you want to add as operations in your application.
Once this is done, click Save Changes. This will create the specified application.
Upload the application on IBM webMethods Integration
Once you have created the application, you need to upload it to IBM webMethods Integration in order to use it in your workflow or Flow service. When you upload an application to IBM webMethods Integration, the metadata of its services such as name, description, and Input/Output signature is also uploaded to that application.
To upload the application, go to webMethods Cloud > Applications, locate the application you want to upload in the webMethods Cloud Applications list, and click Upload.
With this, you have successfully created the application in your webMethods Integration Server, which you can use in your IBM webMethods Integration workflows and Flow services.
Use the uploaded application in a Workflow
Let us see how to use this application in a workflow. Log in to IBM webMethods Integration. You will find the uploaded application (onPremise_app) in the Connectors panel on the right-side of the canvas.
You can use this application like any other connector in your workflow.
When you double-click on the application icon (onPremise_app), you can see that the configuration window is same as that of any other connector available in IBM webMethods Integration. Select the action (myService) and click Next.
You will be redirected to the action configuration screen, where you can add the relevant details to execute the action.
You can optionally test the action and then click Done. This will take you back to the canvas. Once you have configured the rest of the workflow, save it.
Whenever you run the workflow, IBM webMethods Integration sends the request to Integration Server to execute the added application and Integration Server in turn sends back the execution response to IBM webMethods Integration. This data can then be used to execute the rest of the workflow.
Note
A workflow which contains an on-premises connector, cannot be cloned.
Invoke Flow services for on-premises connectors
Click here to see an example on how to invoke Flow services for on-premises connectors.
Dedicated infrastructure support for hybrid integration scenarios
Performance, scalability, and availability of on-premises connectivity for hybrid integration scenarios have been enhanced by having dedicated Universal Messaging (UM) nodes for each tenant.
A tenant can be configured with dedicated UMs based on the license. Contact IBM support for assistance in setting up the dedicated hybrid infrastructure.
If dedicated UMs are provisioned for your tenants, and the shared UM queues, if applicable, are imported to the new dedicated UMs, ensure that you update the settings so that hybrid integrations work with the newly provisioned dedicated UMs.
Routing mechanism improvements
Routing mechanism of the hybrid integration solution is enhanced from the v10.16 release. In the hybrid integration solution, IBM webMethods Integration uses Universal Messaging (UM) to route messages to the on-premises applications and vice-versa.
While configuring the connectivity (routing) settings, currently the host name is provided in the format, um.int-aws-de.webmethods.io. In the new approach, the host name format has been changed to *.um.int-aws-de.webmethods.io, where * indicates the tenant-specific identifier.
Example:
Old UM URL: nhps://um.int-aws-de.webmethods.io:443//stage00-um-1397192613 -1012/
New UM URL: nhps://tenant subdomain-ade43fe.um.int-aws-de.webmethods.io:443//tenant subdomain/, where ade43fe is a unique number generated by the system to identify the Integration Server.
To migrate to the new hybrid routing mechanism, it is recommended to click the Update Settings option and restart the on-premises Integration Server. On-premises Integration Server remains connected to the old Universal Messaging URL unless the settings are updated and the Integration Server is restarted.
Ensure that you allow the following domains in your firewall or proxy settings:
Region
Allowed domains
US1 Oregon AWS
*.um.int-aws-us.webmethods.io
EU2 Frankfurt AWS
*.um.int-aws-de.webmethods.io
AU2 Sydney AWS
*.um.int-aws-au.webmethods.io
US2 East Azure
*.um.int-az-us.webmethods.io
EU3 West Azure
*.um.int-az-eu.webmethods.io
AU1 Australia East Azure
*.um.int-az-au.webmethods.io
Note
For the list of allowed IPs, see the IP Addresses page.
webMethods Integration Server 10.7 and later versions support two-way SSL communication between the on-premises Integration Server and IBM webMethods Integration. Integration Server, by default, supports one-way SSL communication in which the on-premises Integration Server acts as a client and validates the certificate issued by IBM webMethods Integration that acts as a server.
In two-way SSL communication, both the on-premises Integration Server and IBM webMethods Integration validate each other’s certificate. If you want more secure communication between two business applications, you can set up two-way SSL communication.
How to set up two-way SSL communication
Let us see how to set up two-way SSL communication between the on-premises Integration Server and IBM webMethods Integration.
Note
Before you set up a two-way SSL communication, you need to download the IBM webMethods Integration signed certificate and generate a keystore file. Then use the keystore file to generate a keystore alias on the on-premises Integration Server. When you set up a connection to IBM webMethods Integration, you need to use these keystore details so that IBM webMethods Integration can validate the certificate.
Ensure that you have Integration Server 10.7 or any later version installed for two-way SSL communication.
Further, if you are using on-premises Integration Server v10.15 for hybrid connectivity, and if your hybrid connectivity uses two-way SSL, ensure that you have installed IS_10.15_WmCloud_Fix1 or higher in your environment.
Go to IBM webMethods Integration and click Profile > Settings > Client Certificate > Tenant Certificate. Download the webMethods signed certificate file in jks or pkcs12 format, which contains the private key and the certificate. You can also upload your own CA signed certificate. You can either directly generate the jks or pkcs12 file, or if you have generated a text file, use the JKS tools or utilities to generate the JKS file.
Note
IBM webMethods Integration does not support uploading self signed certificates.
Go to Integration Server, add the certificate file, and specify the keystore properties in the Security > Keystore > Create Keystore Alias page. Provide the file path in the Location field and specify the keystore password. Click Submit.
Note
The default password is changeit. You should update the password for enhanced security.
In Integration Server Administrator, click webMethods Cloud > Tenant connections (Settings) and specify the details.
Field
Description
User Name
User name for an account on IBM webMethods Integration.
Password
Password identified in the user account for User Name.
webMethods Cloud URL
The URL of IBM webMethods Integration with which to share accounts and applications created on the on-premises Integration Server. The URL format is: https://sub-domain.domain-name, for example, https://sample.int-aws-us.webmethods.io:8443. For two-way SSL communication, add port 8443 in the URL, for example, https://sub-domain.domain-name:8443.
Under Certificate Settings (optional), complete the fields if you want to set up a two-way SSL communication with IBM webMethods Integration. If you do not configure these settings, Integration Server uses one-way SSL communication with IBM webMethods Integration.
Important
If you do not specify a truststore alias on the webMethods Cloud > Tenant connections > Create tenant connections page, Integration Server relies on the certificates in the JVM truststore for one-way SSL communication. The certificate issued by IBM webMethods Integration uses CAs that are trusted by the JVM and are part of the JVM truststore. You might need to create a truststore if you connect to IBM webMethods Integration using an intermediate proxy or other internal endpoints and the intermediaries use CA certificates that are signed by private CAs. If you override the JVM truststore with your own truststore, ensure that you update your truststore to include the required CAs from the JVM truststore.
Field
Description
Keystore Alias
A user-specified, text identifier for the Integration Server keystore. This is the alias for the keystore that contains the client certificates that you want Integration Server to use when connecting to IBM webMethods Integration. Select the same keystore alias that you have created in Integration Server. A keystore alias is required for two-way SSL. If the JVM is not configured to have a keystore and key alias or you do not want to use the JVM keystore, you must specify a value for Keystore Alias.
Key Alias
The alias for the private key, which must be stored in the keystore specified by the above keystore alias. This value is automatically selected. A key alias is required for two-way SSL. If the JVM is not configured to have a keystore and key alias or you do not want to use the JVM keystore, you must specify a value for Key Alias.
Truststore Alias
The alias for the truststore that contains the CA certificates accepted by the IBM webMethods Integration endpoint and any intermediate endpoints or proxies. Select Default_JVM_Truststore. The truststore must contain the trusted root certificate for the CA that signed the Integration Server certificate associated with the key alias. The truststore also contains the list of CA certificates that Integration Server uses to validate the trust relationship.
Note
If the connection to IBM webMethods Integration involves intermediate endpoints that use certificates signed by private CAs, the selected truststore alias must be for a truststore that contains the CA certificates for the private CA. This truststore might also include the certificates for the JVM.
Click Update Settings. Integration Server connects to IBM webMethods Integration specified in the webMethods Cloud URL field and downloads the configuration information that is required to receive any incoming requests.
Create an account in Integration Server.
Create the application in Integration Server.
Select the account and upload the application to IBM webMethods Integration.
The application is listed on the On-Premises Connectors page in IBM webMethods Integration.
Setting Maximum Thread Pool Usage for Cloud Requests
When an application developed on IBM webMethods Integration invokes a service on an on-premise Integration Server, the on-premise Integration Server uses a thread from the server thread pool to process the service request. The processing thread invokes the service, posts the response, and then terminates, which frees up the thread to process other requests. The on-premises Integration Server can process multiple service requests from IBM webMethods Integration simultaneously.
The watt.server.threadPool.cloudRequests specifies the maximum percentage of the server thread pool that can be used for processing IBM webMethods Integration requests. The default is 5 which means that if the maximum size of the server thread pool is 1000, up to 50 server threads at a time can be used to process cloud requests. If the watt.server.threadPool.cloudRequests value is either undefined or configured to generate fewer than 25 threads, Integration Server automatically adjusts the thread count to a minimum of 25 to handle IBM webMethods Integration requests effectively.
At start up, Integration Server uses the specified percentage to calculate the number of threads that can be used and logs a message with that information to the server.log. At run-time, when Integration Server reaches the maximum number of threads that can be used to process requests from IBM webMethods Integration, Integration Server writes the following message and blocks new server requests from IBM webMethods Integration until a thread becomes available: [ISS.0021.8040W] Server thread pool is using the maximum number of threads allowed for processing requests from webMethods Cloud. Requests from webMethods Cloud will block until a thread becomes available.
Concurrent Hybrid Request Handling
To help ensure that an on-premises Integration Server processes an optimal number of hybrid requests based on the available server capacity, Integration Server sets the number of concurrent hybrid requests it can handle to the lesser of the following:
The number of threads in the server thread pool that can be used for processing cloud requests as determined by the watt.server.threadPool.cloudRequests value.
100 requests.
For example, if the watt.server.threadPool.cloudRequests value indicates that 45 threads in the server thread pool can be used for processing cloud requests, the on-premises Integration Server ensures that it handles 45 hybrid requests concurrently, if there are 45 or more hybrid requests that need to be processed.
Configuring Retry Functionality for Sending Responses
No subtopics in this section
Integration Server uses a transactional publish when sending responses to IBM webMethods Integration. The transactional publish includes a built-in mechanism to recover from intermittent network errors, which can help mitigate the impacts of timeout errors and connection leaks. Integration Server automatically retries any failed transactional publish.
Use the following server configuration parameters to configure the retry functionality for publishing responses to IBM webMethods Integration.
watt.wmcloud.sendResponse.retryCount: Specifies the maximum number of retry attempts that an on-premises Integration Server makes when a failure occurs when sending a response to IBM webMethods Integration. The default value is 3. A value of 0 indicates that Integration Server will not attempt any retries. Integration Server does not need to be
restarted for changes to this parameter to take effect.
watt.wmcloud.sendResponse.retryDelay: Specifies the number of milliseconds that an on-premise Integration Server waits before making another retry attempt after a publish attempt fails. The default value is 1000, that is, one second. Integration Server does not need to be restarted for changes to this parameter to take effect.
If the maximum retry attempts have been made and publishing a response to IBM webMethods Integration still fails, the on-premises Integration Server writes an error to the server log. However, if a response payload exceeds the configured maximum buffer size, then Integration Server does not retry publishing the response to IBM webMethods Integration, but sends an exception to IBM webMethods Integration.
Note
Setting the server log facility 0021 Integration Cloud to the Info level or to a more verbose level may assist with debugging any publish failures.
Monitoring webMethods.io Integration Tenants
No subtopics in this section
The wm.client.integrationlive.admin:scheduleTenantMonitoringTask task runs in Integration Server at the specified interval of 10 minutes to monitor the tenant connections. If a tenant connection fails, Integration Server notifies the user through a notification in Integration Server Administrator followed by an email. Configure the hybrid activity notifications using the
watt.wmcloud.hybridConnectivityAlert.notifications server configuration parameter and the recipients of the notification emails using the watt.wmcloud.hybridConnectivityAlert.mail server configuration parameter. Integration Server uses the email notification settings configured in Integration Server Administrator > Settings > Resources .
For more information, see the webMethods Integration Server Administrator’s Guide.