第 13 章 过滤消息
AMQ Broker 根据 SQL 92 表达式语法的子集提供强大的过滤器语言。过滤器语言使用与 JMS 选择器相同的语法,但预定义的标识符有所不同。下表列出了应用到 AMQ Broker 消息的标识符。
identifier | 属性 |
---|---|
AMQPriority |
消息的优先级。消息优先级是值为 |
AMQExpiration | 消息的过期时间。该值是一个长整数。 |
AMQDurable |
消息是否是 durable。该值是一个字符串。有效值为 |
AMQTimestamp | 创建消息的时间戳。该值是一个长整数。 |
AMQSize |
消息的 |
假设核心过滤器表达式中使用的任何其他标识符都假定是消息的属性。有关 JMS 消息选择器语法的文档,请参阅 Java EE API。
13.1. 配置队列以使用过滤器
您可以在 < broker_instance_dir> /etc/broker.xml
中配置的队列中添加过滤器。只有与过滤器表达式匹配的消息才会进入队列。
流程
将
filter
元素添加到所需的队列
,并包含您要应用的作为元素值的过滤器。在以下示例中,filterNEWS='certification'
添加到队列 TechnologyQueue
中。<configuration> <core> ... <addresses> <address name="myQueue"> <anycast> <queue name="myQueue"> <filter string="NEWS='technology'"/> </queue> </anycast> </address> </addresses> </core> </configuration>