![]() ![]() ![]() ![]() ![]() ![]() |
You can select JMS as the transport protocol for proxy and business services of any service type (except Transport Typed Service type for business service). The proxy services and business services can be configured to use the JMS transport as described in:
For more information, see Business Services: Creating and Managing and Proxy Services: Creating and Managing in Using the Oracle Service Bus Console. For information about error handling for business services, see Error Handling.
When you configure a proxy service, you can use a Transport Header action to set the header values in messages. For more information, see Transport Headers.
For information about interoperability of Oracle Service Bus with WebSphere MQ, see Using the WebSphere JMS MQ Interface in Native MQ Transport User Guide.
In Oracle Service Bus, you can use the default dispatch policy when you configure a service or, optionally, configure custom work managers in WLS. For more information, see “Creating a Work Manager” in Using the WS Transport in WS Transport User Guide.
You can select the JMS transport protocol when you configure any type of proxy service and the endpoint URI is of the form:
jms://<
host:port[,host:port]*/factoryJndiName/destJndiName>
host
: is the name of the system that hosts the service.In a cluster: The host names in the JMS URI must exactly match the host names of the cluster servers as they are configured in WebLogic Server.
port
: is the port number at which the connection is made.[,host:port]*:
indicates that you can configure multiple hosts with corresponding ports.factoryJndiName
:
The name of the JNDI Connection Factory. For more information on how to define a connection factory queue, see
Configure resources for JMS system modules in Administration Console Online Help.destJndiName
: is the name of the JNDI destination.
To target a JMS destination to multiple servers, use the following format of the URI: jms://
host1:port,host2:port/QueueConnectionFactory/destJndiName
where QueueConnectionFactory
is name of the connection factory queue. For more information on how to define a connection factory queue, see
Configure resources for JMS system modules in Administration Console Online Help.
To configure a proxy service using JMS transport protocol you must specify values for the following fields:
JMS Correlation ID
design pattern for your message if you want to correlate by JMS Correlation ID and send the response to the URI configured in the Response URI
field.Note: | The Response URI field is active only when you select JMS Correlation ID design pattern for your response message. |
JMSReplyTo Destination
by configuring the Response Connection Factory
field. Note: | The Response Connection Factory field is active only when you select JMS Message ID design pattern for your response message. |
Bytes
or Text
.UTF-8
. UTF-8
.Dispatch Policy: This specifies the dispatch policy for the endpoint. You must configure Work Managers in the WebLogic Server Administration Console in order to have other dispatch policies in addition to the default dispatch policy. For information about work managers, see Using Work Managers to Optimize Scheduled Work and Create Work Manager in WebLogic Server Administration Console Online Help.
You can set the following parameters in the section:
Topic
. For more information about configuring proxy services using JMS transport, see JMS Transport Configuration Page in Proxy Services: Creating and Managing in Using the Oracle Service Bus Console.
The various headers related to the JMS transport are listed in Table 3-1. All the headers except the Unit of Order header are common to both outbound requests and inbound response.
This contains the nature of the application data. For more information, see
JMS_IBM_FORMAT.
|
|||
Request exception reports. This also specifies how much of the application data from the message must be retained in the report message. For more information, see
JMS_IBM_Report_Exception.
|
|||
Request expiration reports. This also specifies how much of the application data from the message must be retained in the report message. For more information, see
JMS_IBM_Report_Expiration.
|
|||
Request a confirm on arrival reports. This also specifies how much of the application data from the message must be retained in the report message. For more information, see
JMS_IBM_Report_COA.
|
|||
Request a confirm on delivery reports. This also specifies how much of the application data from the message must be retained in the report message. For more information, see
JMS_IBM_Report_COD.
|
|||
Request a positive action notification reports. For more information, see
JMS_IBM_Report_PAN.
|
|||
Request a positive action notification reports. For more information, see
JMS_IBM_Report_NAN
|
|||
Request that the message identifier of any report or reply message is the same as that of the original message. For more Information, see
JMS_IBM_Report_Pass_Msg_ID.
|
|||
Request that the correlation identifier of any report or reply message is the same as that of the original message. For more information, see
JMS_IBM_Report_Pass_Correl_ID.
|
|||
Request that the message is discarded if it cannot be delivered to its intended destination. For more information, see
JMS_IBM_Report_Discard_Msg.
|
|||
The type of a message. For more information, see
JMS_IBM_MsgType.
|
|||
This indicates the nature of a report message. For more information, see
JMS_IBM_Feedback.
|
|||
Indicates whether the message is the last message in a message group. For more information, see
JMS_IBM_Last_Msg_In_Group.
|
|||
|
You can configure the transport headers for both inbound and outbound requests in the Message Flow. For information about the transport headers related to the JMS transport, see Transport Headers.
In the pipeline, use a Transport Header action to set the header values in messages. For information about adding transport header actions, see Adding Transport Header Actions in Using the Oracle Service Bus Console.
Note: | For information about the limitations for JMS transport headers, see Understanding How the Run Time Uses the Transport Settings in the Test Console in Using the Oracle Service Bus Console and “Limitations to Transport Header Values You Specify in Transport Header Actions” in Modelling Message Flows in Oracle Service Bus User Guide. |
You can select the JMS transport protocol when you configure any type of business service and the endpoint URI is of the form:
jms://<
host:port[,host:port]*/factoryJndiName/destJndiName
>
host
: is the name of the system that hosts the service.In a cluster: The host names in the JMS URI must exactly match the host names of the cluster servers as they are configured in WebLogic Server.
port
: is the port number at which the connection is made.[,host:port]*:
indicates that you can configure multiple hosts with corresponding ports.factoryJndiName
:
The name of the JNDI Connection Factory. For more information on how to define a connection factory queue, see
Configure resources for JMS system modules in Administration Console Online Help.destJndiName
: is the name of the JNDI destination.
To target a target a JMS destination to multiple servers, use the following format of the URI: jms://
host1:port,host2:port/QueueConnectionFactory/destJndiName
where QueueConnectionFactory
is name of the connection factory queue. For more information on how to define a connection factory queue, see
Configure resources for JMS system modules in Administration Console Online Help.
When you register a JMS business service, you must manually edit the URI from the WSDL file when adding it to the service definition. The URI format is as follows:
jms://<host>:<port>/
factoryJndiName
/
destJndiName
To configure a business service using the JMS transport protocol you must specify values for the following fields:
JMS Correlation ID
design pattern for your message if you want to correlate by JMS Correlation ID and send the response to the URI configured in the Response URI
field.Note: | The Response URI field is active only when you select JMS Correlation ID design pattern for your response message. |
JMSReplyTo Destination
by configuring the Response Connection Factory
field. Note: | The Response Connection Factory field is active only when you select JMS Message ID design pattern for your response message. |
Bytes
or Text
.UTF-8
. UTF-8
.default
dispatch policy. For more information on how to configure a Work Manager, see
Create a Global Work Manager in WebLogic Server Administration Console.You can set the following parameters in the section:
0
, which means that the message never expires.Unit of Order
. All the messages in a unit must be processed sequentially in the same order they were created.Note: | This is supported by WebLogic Server 9.0. |
Note: | Configuring a JMS request-response application with response correlation by JMS ID for a business service you must: |
You can configure JMS-transport business services to handle application and communications errors as follows:
You can specify whether or not to retry business service endpoint URIs when application errors occur. For more information, see Retry Application Errors
option in
Creating and Configuring Business Services - Transport Configuration page in Using the Oracle Service Bus Console.
An application error occurs when for a JMS business service configured with request/response, the System.getProperty("com.bea.wli.sb.transports.jms.ErrorPropertyName", "SERVER_ERROR")
property is true
in the response message. In this scenario, the JMS transport provider calls the error method with the TRANSPORT_ERROR_APPLICATION
error code.
You can configure business service URIs to be taken offline when such communication errors occur. When you configure the operational settings for the business service, you can enable the business service endpoint URIs to be taken offline after the specified retry interval. For more information, see “Configuring Operational Settings for Business Services” and “Viewing Business Services Endpoint URIs Metrics” in Monitoring in Using the Oracle Service Bus Console.
Connection errors occur when any JMS exceptions or naming exceptions occur during any of the following activities:
![]() ![]() ![]() |