Как запустить поток один раз, автоматически при запуске мула?
У меня есть класс java, который создает чистую базу данных MongoDB с сеянными коллекциями. Он автоматически определяет, отсутствует ли база данных, и создает ее. Я хотел бы запустить это, когда я начну MuleEsb. Таким образом, мне не нужно помнить, чтобы вызвать его, прежде чем я начну мул. Я надеялся поместить его в поток и запустить этот поток один раз, автоматически, когда мул запустится.
есть ли способ сделать эту одноразовую операцию, когда начинается мул?
--- обновление ---
в соответствии с приведенным ниже разговором я добавил следующее в мою конфигурацию мула, и поток автоматически запускается.
<quartz:connector name="Quartz" validateConnections="true"/>
<flow name="testService1">
<quartz:inbound-endpoint name="runOnce" repeatCount="0" repeatInterval="1" jobName="job1" connector-ref="Quartz">
<quartz:event-generator-job>
<quartz:payload>foo</quartz:payload>
</quartz:event-generator-job>
</quartz:inbound-endpoint>
<logger message="INBOUND HEADERS = #[headers:inbound:*]" level="WARN"/>
</flow>
2 ответов
Я создал JIRA месяц назад, чтобы запросить такую функцию:http://www.mulesoft.org/jira/browse/MULE-6877
пока вы можете использовать трюк:входящая конечная точка кварца с заданием генератора событий repeatCount = 0
что вызовет поток только один раз при запуске.
кроме того, вы можете прослушивать события контекста и вызывать поток при запуске определенного события. Ниже показан прослушиватель, вызывающий запуск и завершение работы поток:
package com.acme;
import org.mule.DefaultMuleEvent;
import org.mule.DefaultMuleMessage;
import org.mule.MessageExchangePattern;
import org.mule.api.MuleException;
import org.mule.api.MuleRuntimeException;
import org.mule.api.context.notification.MuleContextNotificationListener;
import org.mule.config.i18n.MessageFactory;
import org.mule.construct.Flow;
import org.mule.context.notification.MuleContextNotification;
public class FlowInvokingContextListener implements MuleContextNotificationListener<MuleContextNotification>
{
private Flow startingFlow;
private Flow stoppingFlow;
public void onNotification(final MuleContextNotification notification)
{
if (notification.getAction() == MuleContextNotification.CONTEXT_STARTED)
{
sendNotificationToFlow(notification, startingFlow);
}
else if (notification.getAction() == MuleContextNotification.CONTEXT_STOPPING)
{
sendNotificationToFlow(notification, stoppingFlow);
}
}
private void sendNotificationToFlow(final MuleContextNotification notification, final Flow flow)
{
try
{
final DefaultMuleEvent event = new DefaultMuleEvent(new DefaultMuleMessage(notification,
notification.getMuleContext()), MessageExchangePattern.REQUEST_RESPONSE, startingFlow);
flow.process(event);
}
catch (final MuleException me)
{
throw new MuleRuntimeException(MessageFactory.createStaticMessage("Failed to invoke: "
+ startingFlow), me);
}
}
public void setStartingFlow(final Flow startingFlow)
{
this.startingFlow = startingFlow;
}
public void setStoppingFlow(final Flow stoppingFlow)
{
this.stoppingFlow = stoppingFlow;
}
}
конфигурации:
<spring:beans>
<spring:bean name="flowInvokingContextListener"
class="com.acme.FlowInvokingContextListener"
p:startingFlow-ref="startFlow" p:stoppingFlow-ref="stopFlow" />
</spring:beans>
<notifications>
<notification event="CONTEXT" />
<notification-listener ref="flowInvokingContextListener" />
</notifications>
другой вариант-использовать пользовательский агент, который это делает:
http://www.mulesoft.org/documentation/display/current/Mule + агенты