Liferay - 调度程序在给定时间不触发

时间:2015-11-17 11:23:27

标签: java cron liferay scheduler

我一直在尝试在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,它应该只运行一次。我在这里做的错误是什么?

2 个答案:

答案 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