在我的Spring Boot应用程序中,我配置了Embedded Apache ActiveMQ。
@Configuration
@EnableJms
public class ActiveMQConfig {
@Bean
public Queue queue() {
return new ActiveMQQueue("import.decisions.queue");
}
}
为了发送消息,我使用以下代码:
@Autowired
private JmsMessagingTemplate jmsMessagingTemplate;
@Autowired
private Queue queue;
this.jmsMessagingTemplate.convertAndSend(this.queue, message);
现在我使用内存中的ActiveMQ,这是我的application.properties
:
#ActiveMQ
spring.activemq.in-memory=true
spring.activemq.pool.enabled=false
spring.activemq.packages.trust-all=true
因为我不想丢失已经入队的消息,例如在应用程序重启期间,我需要配置嵌入式ActiveMQ以保留数据。
您能否说明如何使用Spring Boot配置完成?
答案 0 :(得分:4)
BrokerService默认是持久的,你做过一些测试吗?
如果您愿意,可以将其定义为覆盖:
ArticleTone.objects.filter(name= 'sad');
或
@Bean(initMethod = "start", destroyMethod = "stop")
public BrokerService broker() throws Exception {
final BrokerService broker = new BrokerService();
//broker.addConnector("tcp://localhost:61616");
broker.addConnector("vm://localhost");
PersistenceAdapter persistenceAdapter = new KahaDBPersistenceAdapter();
File dir = new File(System.getProperty("user.home") + File.separator + "kaha");
if (!dir.exists()) {
dir.mkdirs();
}
persistenceAdapter.setDirectory(dir);
broker.setPersistenceAdapter(persistenceAdapter);
broker.setPersistent(true);
return broker;
}
@Bean(initMethod = "start", destroyMethod = "stop") public BrokerService broker() throws Exception { final BrokerService broker = new BrokerService(); //broker.addConnector("tcp://localhost:61616"); broker.addConnector("vm://localhost"); broker.setPersistent(true); // default messages store is under AMQ_HOME/data/KahaDB/ return broker; }