Synchronous messaging with request-reply pattern¶
This sample demonstrates how you can implement the request-reply messaging scenario (dual-channel scenario) using the RabbitMQ broker and WSO2 Micro Integrator.
As shown below, the OrderRequest
proxy service in the Micro Integrator receives an HTTP
request, which it publishes to a RabbitMQ queue. This message is consumed and processed by the OrderProcessing
proxy service in the Micro Integrator, and the response is sent back to the client over HTTP.
Synapse configurations¶
See the instructions on how to build and run this example.
<?xml version="1.0" encoding="UTF-8"?>
<proxy xmlns="http://ws.apache.org/ns/synapse"
name="OrderRequestService"
transports="http https"
startOnLoad="true">
<description/>
<target>
<inSequence>
<property name="rabbitmq.message.content.type"
value="Content-Type"
scope="axis2"/>
<property name="TRANSPORT_HEADERS" scope="axis2" action="remove"/>
<call>
<endpoint>
<address uri="rabbitmq:/order-request?rabbitmq.server.host.name=localhost&rabbitmq.server.port=5672&rabbitmq.server.user.name=guest&rabbitmq.server.password=guest"/>
</endpoint>
</call>
<respond/>
</inSequence>
</target>
</proxy>
<?xml version="1.0" encoding="UTF-8"?>
<proxy xmlns="http://ws.apache.org/ns/synapse"
name="OrderProcessingService"
transports="rabbitmq"
startOnLoad="true">
<target>
<inSequence>
<call>
<endpoint xmlns="http://ws.apache.org/ns/synapse">
<http method="POST" uri-template="http://localhost:8290/orders"/>
</endpoint>
</call>
<log level="custom">
<property name="Info" value="Your order has been placed successfully."/>
</log>
<respond/>
</inSequence>
<faultSequence>
<payloadFactory media-type="xml">
<format>
<Error>$1</Error>
</format>
<args>
<arg evaluator="xml" expression="get-property('ERROR_MESSAGE')"/>
</args>
</payloadFactory>
<respond/>
</faultSequence>
</target>
<parameter name="rabbitmq.queue.name">order-request</parameter>
<parameter name="rabbitmq.connection.factory">AMQPConnectionFactory</parameter>
</proxy>
We can use the below synapse configurations to act as the mock backend called by the OrderProcessingService
proxy service.
<?xml version="1.0" encoding="UTF-8"?>
<api context="/orders" name="mockOrdersBackend" xmlns="http://ws.apache.org/ns/synapse">
<resource methods="POST">
<inSequence>
<property name="messageType" value="application/json" scope="axis2"/>
<payloadFactory media-type="json">
<format>{"message":"Order created"}</format>
<args/>
</payloadFactory>
<respond/>
</inSequence>
<faultSequence>
<payloadFactory media-type="json">
<format>{"error":"Error processing order"}</format>
<args/>
</payloadFactory>
<respond/>
</faultSequence>
</resource>
</api>
Build and run¶
-
Launch Visual Studio Code with the Micro Integrator for VS Code extension (MI for VS Code) installed.
Info
Follow the Install Micro Integrator for VS Code documentation for a complete installation guide.
-
Create an integration project.
- Create the proxy service with the configurations given above.
- Enable the RabbitMQ sender and receiver in the Micro-Integrator from the deployment.toml. Refer the configuring RabbitMQ documentation for more information.
- Deploy the artifacts in your Micro Integrator.
- Make sure you have a RabbitMQ broker instance running.
-
Send a message to the
Order Request Proxy Service
with the following payload.{ "orderId": "1242", "orderQty": 43, "orderDate": "2020/07/22" }