Sample 705: Introduction to Message Forwarding Processor With Advance Parameters
            
<!-- Introduction to Message Forwarding Processor With max deliver attempt and drop
                the message after max deliver attempt-->
                <definitions xmlns="http://ws.apache.org/ns/synapse">
                <endpoint name="StockQuoteServiceEp">
                <address uri="http://localhost:9000/services/SimpleStockQuoteService">
                <suspendOnFailure>
                <errorCodes>-1</errorCodes>
                <progressionFactor>1.0</progressionFactor>
                </suspendOnFailure>
                </address>
                </endpoint>
                <sequence name="fault">
                <log level="full">
                <property name="MESSAGE" value="Executing default 'fault' sequence"/>
                <property name="ERROR_CODE" expression="get-property('ERROR_CODE')"/>
                <property name="ERROR_MESSAGE" expression="get-property('ERROR_MESSAGE')"/>
                </log>
                <drop/>
                </sequence>
                <sequence name="main">
                <in>
                <log level="full"/>
                <property name="FORCE_SC_ACCEPTED" value="true" scope="axis2"/>
                <property name="OUT_ONLY" value="true"/>
                <property name="target.endpoint" value="StockQuoteServiceEp"/>
                <store messageStore="MyStore"/>
                </in>
                <description>The main sequence for the message mediation</description>
                </sequence>
                <messageStore name="MyStore"/>
                <messageProcessor
                class="org.apache.synapse.message.processors.forward.ScheduledMessageForwardingProcessor"
                name="ScheduledProcessor" messageStore="MyStore">
                <parameter name="interval">10000</parameter>
                <parameter name="max.deliver.attempts">3</parameter>
                <parameter name="max.deliver.drop">true</parameter>
                </messageProcessor>
                </definitions>
            
            
Objective
                
                    Introduction to Synapse Scheduled Message Forwarding Processor with advance parameters (max deliver
                    attempt and drop the message after max deliver attempt)
                
             
            
            
Executing the Client
                
                    Execute the sample client a few times with the following command.
                
                
                    ant stockquote -Daddurl=http://localhost:9000/services/SimpleStockQuoteService -Dtrpurl=http://localhost:8280/ -Dmode=placeorder
                
                
                    When you start to send request to synapse from client, you will see message forwarding processor without
                    getting deactivate it keep on processing. This is due to the message will be dropped from the message store after
                    the maximum number of delivery attempts are made, and the message processor will remain activated.
                    "max.deliver.drop" parameter would have no effect when no value is specified for the Maximum Delivery Attempts parameter.
                    If this parameter is disabled, the undeliverable message will not be dropped and the message processor will be deactivated.
                
             
         
        
            Back to Catalog