在Quartz SCheduler中使用Apache骆驼的问题

问题描述 投票:0回答:3

我是Apache骆驼和石英调度程序的新手。我试图在集成中同时使用它们,但无法做到。我在“ Camel in Action”书中找到了一篇小文章,但我也没有设法运行该程序-这是我的代码

package com.cockpitconfig.schedulars;

import org.apache.camel.CamelContext;
import org.apache.camel.builder.RouteBuilder;
import org.apache.camel.impl.DefaultCamelContext;

public class TestScheduler {

    public static void main(String args[]) throws Exception {
        CamelContext context = new DefaultCamelContext();
        context.disableJMX();
        context.addRoutes(new RouteBuilder() {
            @Override
            public void configure() {
                from(
                        "quartz://myTimer?trigger.repeatInterval=2000&trigger.repeatCount=-1")
                        .setBody().simple("Current time is ").to("stream:out");
            }
        });

        context.start();
        Thread.sleep(10000);

        context.stop();
    }
}

但是它给出了错误

Exception in thread "main" java.lang.InstantiationError: org.quartz.SimpleTrigger
    at org.apache.camel.component.quartz.QuartzComponent.createEndpoint(QuartzComponent.java:119)
    at org.apache.camel.component.quartz.QuartzComponent.createEndpoint(QuartzComponent.java:54)
    at org.apache.camel.impl.DefaultComponent.createEndpoint(DefaultComponent.java:75)
    at org.apache.camel.impl.DefaultCamelContext.getEndpoint(DefaultCamelContext.java:419)
    at org.apache.camel.util.CamelContextHelper.getMandatoryEndpoint(CamelContextHelper.java:47)
    at org.apache.camel.model.RouteDefinition.resolveEndpoint(RouteDefinition.java:189)
    at org.apache.camel.impl.DefaultRouteContext.resolveEndpoint(DefaultRouteContext.java:110)
    at org.apache.camel.impl.DefaultRouteContext.resolveEndpoint(DefaultRouteContext.java:116)
    at org.apache.camel.model.FromDefinition.resolveEndpoint(FromDefinition.java:73)
    at org.apache.camel.impl.DefaultRouteContext.getEndpoint(DefaultRouteContext.java:88)
    at org.apache.camel.model.RouteDefinition.addRoutes(RouteDefinition.java:751)
    at org.apache.camel.model.RouteDefinition.addRoutes(RouteDefinition.java:174)
    at org.apache.camel.impl.DefaultCamelContext.startRoute(DefaultCamelContext.java:610)
    at org.apache.camel.impl.DefaultCamelContext.startRouteDefinitions(DefaultCamelContext.java:1514)
    at org.apache.camel.impl.DefaultCamelContext.doStartCamel(DefaultCamelContext.java:1306)
    at org.apache.camel.impl.DefaultCamelContext.doStart(DefaultCamelContext.java:1213)
    at org.apache.camel.impl.ServiceSupport.start(ServiceSupport.java:65)
    at org.apache.camel.impl.ServiceSupport.start(ServiceSupport.java:52)
    at org.apache.camel.impl.DefaultCamelContext.start(DefaultCamelContext.java:1191)
    at com.cockpitconfig.schedulars.TestScheduler.main(TestScheduler.java:24)

有人可以解决这个问题吗?

quartz-scheduler apache-camel
3个回答
0
投票

您使用的是哪个版本的骆驼?使用2.8-SNAPSHOT对我来说效果很好。只要确保您的路径中有骆驼核心,骆驼石英和骆驼流依赖项即可。


0
投票

从当前的camel-quartz插件文档中并不明显,但是从Camel 2.11.0开始,它仅与Quartz 1.x兼容,并且与Quartz 2.x不兼容(已经存在了几年。 ),因为Quartz 2.x与Spring 3.0不兼容(并且Camel表示它将暂时保持Spring 3.0的兼容性。

此文档记录在this Camel JIRA issue


0
投票

我知道可能已经晚了,但可能会对其他人有所帮助,我创建了一个示例应用程序来解决同一问题。https://github.com/hbothra15/camelQuartzScheduler

感谢@Ted

© www.soinside.com 2019 - 2024. All rights reserved.