第 7 章 分页消息


AMQ Broker 透明地支持在服务器运行时包含数以百万条信息的大型队列,但内存有限。

在这种情况下,无法在任何时间点上将所有队列存储在内存中,因此 AMQ Broker 会根据需要透明地 页面 消息和内存不足,从而允许大量队列占用内存。

逐个地址进行分页。当地址中所有消息的大小超过配置的最大值时,AMQ Broker 将开始向磁盘分页信息。有关地址的更多信息,请参阅配置地址和队列

默认情况下,AMQ Broker 不会页面信息。您必须明确配置分页才能启用它。

如需了解如何使用 AMQ Broker 的 分页 示例,请参阅 INSTALL_DIR/examples/standard/ 下的分页示例。

7.1. 关于页面文件

信息按每个地址保存在文件系统中。每个地址都有一个单独的文件夹,其中消息存储在多个文件中(页面文件)。每个文件将包含最多配置的最大大小的消息(page-size-bytes)。在需要时,系统将导航到文件,一旦所有消息被确认到该点,它将立即删除页面文件。

浏览器将通过 page-cursor 系统读取。

带有选择器的消费者还将浏览 page-files 并忽略不与条件不匹配的消息。

注意

如果您有一个队列,并且消费者使用非常严格的选择器过滤队列时,您可能会遇到一些情况,因为您无法从分页中读取更多数据,直到您消耗来自队列中的消息。

示例:在一个消费者中,使用一个选择器作为 'color="red"',但在蓝色之后只有一个颜色的红色消息,在使用蓝色前,您将无法使用红色。这与浏览不同,因为我们在提供队列时,我们将"浏览"整个队列查找信息,同时我们"页面"消息。

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

© 2024 Red Hat, Inc.