Contact Us 1-800-596-4880

Anypoint MQ ACK and NACK Operations - Mule 4

Acknowledging a message (ACK) informs the Anypoint MQ broker that the message has been processed and must be removed from the queue to prevent redelivery. Not acknowledging a message (NACK) tells the broker to not process the message and to return the message to the queue for redelivery to any available consumer.

Acknowledgment Modes

The Anypoint MQ connector provides three acknowledgment modes:

  • Immediate

    Use Immediate when you want to acknowledge messages as your app consumes them, before processing them.

  • Automatic

    Use Automatic to acknowledge a received message automatically only if the flow execution finishes successfully.

  • Manual

    Use Manual if you want the app logic to control message acknowledgment.

Immediate Acknowledgment

Use the IMMEDIATE acknowledgment mode to acknowledge messages as your app consumes them and before processing them.

When Anypoint MQ acknowledges a message, it removes the message from the queue and doesn’t redeliver it if an error occurs during processing.

If the app restarts between being acknowledged and dispatched, the message might not be available again because it was deleted from the queue. To prevent message deletion until after processing, use the AUTO or MANUAL acknowledgment mode instead.

If an error occurs during message processing using IMMEDIATE mode, Anypoint MQ throws an ANYPOINT-MQ:ACKING error. To manage errors without losing messages, use a dead letter queue.

Automatic Acknowledgment

Use the AUTO acknowledgment mode to acknowledge a received message automatically only if the flow execution finishes successfully.

If an error occurs during flow execution, the message is not acknowledged ('NACK') and the message is returned to the queue for redelivery.

Manual Acknowledgment

Use the MANUAL acknowledgment mode to delegate all responsibility for message acknowledgment to the app logic.

With this configuration, every message received has an ackToken value that identifies this message uniquely for a given connection.

Save this ackToken value to use later as input to the ACK or NACK operations.

Acknowledgment Timeout

When using either AUTO or MANUAL acknowledgment modes, you can use the acknowledgementTimeout parameter to control how long the message remains in-flight waiting to be acknowledged, before automatically returning to the queue. The acknowledgementTimeout timer begins when the message is consumed.

If acknowledgementTimeout is not set, Anypoint MQ Connector uses two minutes. If you need a different TTL, you must define it explicitly in the acknowledgementTimeout parameter of the subscriber.

When using acknowledgementTimeout, consider expected app-time processing, including time for unexpected delays, such as external systems delay and app back-pressure due to high load. For example, if you expect the consumed message to be processed in 10 seconds, set acknowledgementTimeout to a minimum of 15 seconds.

When using the prefetch mode in the Subscriber source, Anypoint MQ attempts to honor the expiration time specified by acknowledgementTimeout. However, Anypoint MQ extends the expiration timeout if the time that the message remains in the buffer reaches 80% of the timeout value.

For this reason, don’t use prefetch mode if the acknowledgementTimeout must be honored.

Acknowledgment Timeout — AUTO Acknowledgement Mode

After a subscriber consumes a message, a timer starts, indicating how long the message has been in-flight for the broker waiting for acknowledgment. If the flow processing does not end with a success or failure before the acknowledgementTimeout limit is reached, the message automatically returns to the queue for redelivery.

Acknowledgment Timeout — MANUAL Acknowledgement Mode

When consuming a message using MANUAL acknowledgment mode by either the Subscriber or Consume operations, the app must execute either an ACK or NACK operation using the message ackToken before the acknowledgementTimeout limit is reached. If neither operation executes with the given token before the timeout, the message automatically returns to the queue for redelivery. Any attempt to acknowledge the message after the timeout limit fails due to an expired token.

ACK Operation — MANUAL Acknowledgement Mode

Acknowledging a message (ACK) informs the broker that the message has been processed and must be removed from the queue to prevent redelivery.

When performing the ACK operation using Manual mode, you must use the acknowledgment token (ackToken) to identify the message. It is available in the ackToken field of the message attributes:

<flow name="consumerWithManualAck">
    <scheduler>
        <scheduling-strategy >
          <fixed-frequency />
        </scheduling-strategy>
    </scheduler>

    <!-- Consume a message -->
    <anypoint-mq:consume destination="${destination}"
         acknowledgementMode="MANUAL"
            config-ref="Anypoint_MQ_Config"/>

    <!-- Save the ackToken for future acknowledgment -->
    <set-variable variableName="currentAckToken"
       value="#[attributes.ackToken]"/>

    <!-- Do the required processing of the message -->
    <flow-ref name="process-message"/>

    <!-- Use the ackToken to ACK the message -->
    <anypoint-mq:ack ackToken="#[vars.currentAckToken]"
         config-ref="Anypoint_MQ_Config" />
</flow>

If a non-void operation is invoked during message processing, the payload and attributes of the Mule message are modified. To perform an ACK operation after processing, you must save ackToken in a variable.

To save attributes to use later, use the target and targetValue parameters to store the whole message in a variable:

<flow name="consumerWithManualAck">
      <scheduler>
        <scheduling-strategy >
          <fixed-frequency />
        </scheduling-strategy>
      </scheduler>

    <!-- Consume a message -->
    <anypoint-mq:consume destination="${destination}"
        acknowledgementMode="MANUAL"
        config-ref="Anypoint_MQ_Config"
        target="mqMessage"
        targetValue="#[message]"/>


    <!--Do any message processing-->
    <jms:publish-consume destination="#[vars.mqMessage.attributes.targetDestination]"
        config-ref="JMS_Config">
        <jms:message>
            <jms:body>#[vars.mqMessage.payload]</jms:body>
        </jms:message>
    </jms:publish-consume>

    <!-- Use the ackToken to ACK the message -->
    <anypoint-mq:ack ackToken="#[vars.mqMessage.attributes.ackToken]"
        config-ref="Anypoint_MQ_Config" />
</flow>

NACK Operation

Not acknowledging (NACK) a message informs the broker that the message was not processed successfully and commands the broker to return the message to the queue for redelivery to any available consumer.

The acknowledgment token ackToken is a unique identifier for the message that you must use when executing the NACK operation. It is available in the ackToken field of the message attributes:

<flow name="consumerWithManualAck">
    <scheduler>
      <scheduling-strategy >
        <fixed-frequency />
      </scheduling-strategy>
    </scheduler>

    <!-- Consume a message -->
    <anypoint-mq:consume destination="${destination}"
           acknowledgementMode="MANUAL"
           config-ref="Anypoint_MQ_Config"
           target="mqMessage"
          targetValue="#[message]"/>

    <!--Do message processing -->
    <logger message="#[payload]"/>

    <!-- Use the ackToken to NACK the message -->
    <anypoint-mq:nack ackToken="#[vars.mqMessage.attributes.ackToken]"
    config-ref="Anypoint_MQ_Config" />
</flow>
View on GitHub