Sophie

Sophie

distrib > Mageia > 6 > armv5tl > media > core-release > by-pkgid > d8df8cf378b99736a2bf51b4f903186b > files > 84

artemis-doc-1.4.0-2.mga6.noarch.rpm

# Scheduled Messages

Scheduled messages differ from normal messages in that they won't be
delivered until a specified time in the future, at the earliest.

To do this, a special property is set on the message before sending it.

## Scheduled Delivery Property

The property name used to identify a scheduled message is
`"_AMQ_SCHED_DELIVERY"` (or the constant
`Message.HDR_SCHEDULED_DELIVERY_TIME`).

The specified value must be a positive `long` corresponding to the time
the message must be delivered (in milliseconds). An example of sending a
scheduled message using the JMS API is as follows.

``` java
TextMessage message = session.createTextMessage("This is a scheduled message message which will be delivered in 5 sec.");
message.setLongProperty("_AMQ_SCHED_DELIVERY", System.currentTimeMillis() + 5000);
producer.send(message);

...

// message will not be received immediately but 5 seconds later
TextMessage messageReceived = (TextMessage) consumer.receive();
```
Scheduled messages can also be sent using the core API, by setting the
same property on the core message before sending.

## Example

See the [examples](examples.md) chapter for an example which shows how scheduled messages can be used with
JMS.