我一直在尝试在Liferay中实现调度程序作业。我的控制器如下所示。
public class MyController {
@RenderMapping
public String defaultView() {
String cron = "0 0 11 1/1 * ? *";
Date dt = new Date();
Calendar calendar = Calendar.getInstance();
calendar.setTime(dt);
calendar.add(Calendar.MINUTE, 2);
Trigger trigger = null;
try {
trigger = TriggerFactoryUtil.buildTrigger(TriggerType.CRON, Scheduler.class.getName(), Scheduler.class.getName(), calendar.getTime(), null, cron);
} catch (SchedulerException e) {
e.printStackTrace();
}
Portlet portlet = PortletLocalServiceUtil.getPortletById("portlet_id");
Message message = new Message();
message.put("CONTEXT_PATH", portlet.getContextPath());
message.put(SchedulerEngine.MESSAGE_LISTENER_CLASS_NAME, Scheduler.class.getName());
message.put(SchedulerEngine.PORTLET_ID, portlet.getPortletId());
Scheduler scheduler = new Scheduler();
MessageBusUtil.registerMessageListener(DestinationNames.SCHEDULER_DISPATCH, scheduler);
try {
SchedulerEngineHelperUtil.schedule( trigger, StorageType.PERSISTED, "", DestinationNames.SCHEDULER_DISPATCH, message, 5);
} catch (SchedulerException e) {
e.printStackTrace();
}
return "view";
}
}
Scheduler
类定义如下
public class Scheduler implements MessageListener {
@Override
public void receive(Message message) throws MessageListenerException {
myMethodAtScheduledTime();
}
public void myMethodAtScheduledTime() {
System.out.println("Invoked at " + new Date());
}
}
我没有在liferay-portlet.xml
中提供cron时间,因为我需要用户配置它。因此,对于测试,我将cron时间设置为每天触发11.00。
但是,即使我将我的cron时间设置为上午11点,作业也会在下一秒开始(甚至在11.00之前),它永远不会结束。它每10-20秒继续调用一次。我想将作业调用精确地限制为11.00,它应该只运行一次。我在这里做的错误是什么?
答案 0 :(得分:1)
我已经解决了这个问题。我不确定错误在哪里。但是当我替换以下代码而不是上面的控制器代码时,我能够在确切的时间触发调度程序。
public class MyController {
@RenderMapping
public String defaultView() {
try {
String cron = "0 0 11 1/1 * ? *";
String description = "";
String destinationName = DestinationNames.SCHEDULER_DISPATCH;
int exceptionsMaxSize = 0;
String portletId = "portlet_id";
Message message = new Message();
message.put(SchedulerEngine.MESSAGE_LISTENER_CLASS_NAME, Scheduler.class.getName());
message.put(SchedulerEngine.PORTLET_ID, portletId);
Trigger trigger = new CronTrigger(Scheduler.class.getName(), Scheduler.class.getName(), cron);
SchedulerEngineHelperUtil.schedule(trigger, StorageType.PERSISTED, description, destinationName, message, exceptionsMaxSize);
} catch (SchedulerException e) {
e.printStackTrace();
}
return "view";
}
}
问题应该是我正在制作错误的Trigger
对象或错误地调用registerMessageListener
方法。
答案 1 :(得分:0)
此url也可以获得有关调度程序的更多详细信息
http://liferaytutorial.blogspot.in/2014/07/creating-scheduler-dynamically-in.html