jbpm4.4 timer的使用

今天学习了jbpm4 的timer使用,一直测试都不成功:配置如下:

<?xml version="1.0" encoding="UTF-8"?>

<process key="TimerTransition" name="TimerTransition" xmlns="http://jbpm.org/4.4/jpdl">

    <start g="0,75,80,40">
        <transition to="guardedWait"/>
    </start>

    <state g="202,96,108,40" name="guardedWait">
        <transition g="-49,-22" name="timeout" to="escalation">
            <timer duedate="5 seconds"/>
        </transition>
    </state>

    <state g="456,118,80,40" name="escalation"/>

</process>

如图,设置为5秒后自动到达escalation节点,部署完任务后调用:

ProcessInstance instance = super.executionService
                .startProcessInstanceByKey("TimerTransition");

然后5s后获取当前位置:

ProcessInstance instance = super.executionService
                .findProcessInstanceById("TimerTransition.260001");
        System.out.println(instance.findActiveActivityNames().toString());

每次获取都是在节点guardedwait节点中,甚是郁闷。

后来想想才明白,我程序部署完后就停止了,不是web环境的,任务执行完了就停止了,job根本无法执行,后来改了如下:

ProcessInstance instance = super.executionService
                .startProcessInstanceByKey("TimerTransition");
        Job job = managementService.createJobQuery().timers()
                .processInstanceId(instance.getId()).uniqueResult();
        System.out.println("job到期:" + job.getDuedate());
        // ProcessInstance instance = super.executionService
        // .findProcessInstanceById("TimerTransition.910001");
        try
        {
            Thread.sleep(5000);
        } catch (InterruptedException e)
        {
            e.printStackTrace();
        }
        String name = instance.findActiveActivityNames().toString();
        System.out.println("当前节点:" + name);

        System.out.println("instanceId:" + instance.getId());

ok执行成功,成功自动运行到节点es










posted @ 2014-01-13 19:53  小小架构师  阅读(103)  评论(0编辑  收藏  举报