1

我开发了 Flex - Java - 我已部署到 Amazon EC2 映像中的 Spring Web 应用程序 - 一切看起来都很棒。

但是,我需要在位于不同机器上的应用程序的多个实例之间自动扩展和共享用户请求,即不在同一个 Tomcat 容器内。Amazon 管理负载平衡,应用程序使用 AMQ 主题在每个实例之间传达关键的应用程序级别更改。

这些通知之一可能是属性。我有几个属性文件,我使用 @Value 注释将它们注入到相关的 Spring bean 中。这些属性文件位于类路径根目录 (classpath:properties/) 的属性文件夹中

在单个节点上操作时,当我更新属性时,我使用 setter 更新内存中的值,并使用 FileInputStream 和 FileOutputStream 将更改写回相关的属性文件。这很容易。

但是,现在明显的问题是,当我自动缩放并在不同的容器中启动新实例时会发生什么?此应用程序将读取属性文件的已部署(旧)版本,并最终表现出与其他并行节点不同的行为。

如果可以的话,我真的很想在数据库上维护基于文件的配置——我知道数据库解决方案将是这里最普遍的响应,但任何建议都会受到赞赏。

谢谢

4

1 回答 1

0

就您已经在使用 JMS 主题而言,我建议您使用持久订阅。

如果客户端需要接收在某个主题上发布的所有消息,包括在订阅者处于非活动状态时发布的消息,它会使用持久的 TopicSubscriber。JMS 提供者保留此持久订阅的记录,并确保保留来自主题发布者的所有消息,直到它们被此持久订阅者确认或它们已过期。

看看 JMS API:http ://docs.oracle.com/javaee/6/api/javax/jms/Session.html#createDurableSubscriber(javax.jms.Topic , java.lang.String)

于 2012-08-29T16:29:03.390 回答