ActiveMQ學習(四)消息的Headers

一個消息對象分為三部分:消息頭(Headers),屬性(Properties)和消息體(Payload)。對于StreamMessage和MapMessage,消息本身就有特定的結構,而對于TextMessage,ObjectMessage和BytesMessage是無結構的。一個消息可以包含一些重要的數據或者僅僅是一個事件的通知。

消息的Headers部分通常包含一些消息的描述信息,它們都是標準的描述信息。包含下面一些值:

  • JMSDestination
    消息的目的地,Topic或者是Queue。

  • JMSDeliveryMode
    消息的發送模式:persistent或nonpersistent。前者表示消息在被消費之前,如果JMS提供者DOWN了,重新啟動后消息仍然存在。后者在這種情況下表示消息會被丟失。可以通過下面的方式設置:
    Producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);

  • JMSTimestamp
    當調用send()方法的時候,JMSTimestamp會被自動設置為當前時間。可以通過下面方式得到這個值:
    long timestamp = message.getJMSTimestamp();

  • JMSExpiration
    表示一個消息的有效期。只有在這個有效期內,消息消費者才可以消費這個消息。默認值為0,表示消息永不過期。可以通過下面的方式設置:
    producer.setTimeToLive(3600000); //有效期1小時 (1000毫秒 * 60秒 * 60分)

  • JMSPriority
    消息的優先級。0-4為正常的優先級,5-9為高優先級。可以通過下面方式設置:
    producer.setPriority(9);

  • JMSMessageID
    一個字符串用來唯一標示一個消息。

  • JMSReplyTo
    有時消息生產者希望消費者回復一個消息,JMSReplyTo為一個Destination,表示需要回復的目的地。當然消費者可以不理會它。

  • JMSCorrelationID
    通常用來關聯多個Message。例如需要回復一個消息,可以把JMSCorrelationID設置為所收到的消息的JMSMessageID。

  • JMSType
    表示消息體的結構,和JMS提供者有關。

  • JMSRedelivered
    如果這個值為true,表示消息是被重新發送了。因為有時消費者沒有確認他已經收到消息或者JMS提供者不確定消費者是否已經收到。

除了Header,消息發送者可以添加一些屬性(Properties)。這些屬性可以是應用自定義的屬性,JMS定義的屬性和JMS提供者定義的屬性。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容