2

在备份期间,我想暂停 HornetQ 中的所有 JMS 队列,以便拍摄磁盘快照。在jboss-cli我打电话:

connect   
/subsystem=messaging/hornetq-server=default/jms-queue=%queueName:pause

但是队列没有暂停。如何暂停所有 JMS 作业?

UPD

重现步骤:

root@debian:/opt/jboss/bin# ./jboss-cli.sh 
You are disconnected at the moment. Type 'connect' to connect to the server or 'help' for the list of supported commands.
[disconnected /] connect
[standalone@localhost:9999 /] /subsystem=messaging/hornetq-server=default/jms-queue=AIIndex:pause         
{
    "outcome" => "success",
    "result" => undefined
}
[standalone@localhost:9999 /] 

但是当我打电话时

[standalone@localhost:9999 /] /subsystem=messaging/hornetq-server=default/jms-queue=AIIndex:count-messages
{
"outcome" => "success",
 "result" => 128L
}

因此,每当我调用 /subsystem=messaging/hornetq-server=default/jms-queue=AIIndex:count-messages它时,它都会显示不同的值。

4

1 回答 1

3

我可以重现它:pause只是禁用消息接收(接收者不会收到任何消息,并且没有错误消息)。但是仍然可以发送消息。我也没有找到任何其他操作,无论是在队列上还是在子系统级别上。所以我只能确认它不像“预期的”那样工作。


HornetQ 在内部使用日志。一个报价:

HornetQ 日志仅附加一个可配置的文件大小,通过启用单次写入操作来提高性能。它由磁盘上的一组文件组成,这些文件最初预先创建为固定大小并填充有填充。随着服务器操作(添加消息、删除消息、更新消息等)的执行,操作记录会附加到日志中,直到日志文件已满,此时使用下一个日志文件。

至于日志刷新/同步另一个报价:

日志同步事务

如果为真,HornetQ 确保所有事务数据在事务边界(提交、准备和回滚)上刷新到磁盘。默认值为真。

日志同步非事务性

如果为真,HornetQ 确保将非事务性消息数据(发送和确认)刷新到磁盘。默认值为真。

这看起来还不错,但我还没有找到可以备份.../data/messaging*/目录的确认。可能没有从“外部”获得一致备份的解决方案。


所以我知道的唯一可靠的方法是使用主动/被动设置:引用:

HornetQ 允许成对的服务器作为实时-备份对链接在一起。在此版本中,每个实时服务器都有一个备份服务器。备份服务器仅由一台实时服务器拥有。在发生故障转移之前,备份服务器无法运行。

这种方法从“在 JBoss 内”工作以进行备份(虽然这不是文件系统备份)。

于 2013-08-26T11:23:28.847 回答