2011-07-07 29 views
1

我试图使用Quartz 1.8.5初始化Quartz调度(我也试过Quartz2.0 - 同样的问题)使用Spring 3.0.0。 不过,我不想使用Spring的工具包装的石英调度,触发器,工作... 我想从我的应用程序编程创建所有这些对象,就像在一个没有容器 独立的Java应用程序 - 许多的原因,但主要是因为我有 动态触发器和JobDetails要求...不能在春

所以,我在类路径中,在那里我定义了一个JobStoreTX我quartz.properties:

org.quartz.scheduler.instanceName: NotificationsScheduler 
org.quartz.scheduler.instanceId: AUTO 
org.quartz.scheduler.skipUpdateCheck: true 

org.quartz.threadPool.class: org.quartz.simpl.SimpleThreadPool 
org.quartz.threadPool.threadCount: 3 
org.quartz.threadPool.threadPriority: 5 

org.quartz.jobStore.misfireThreshold: 60000 

org.quartz.jobStore.class: org.quartz.impl.jdbcjobstore.JobStoreTX 
org.quartz.jobStore.driverDelegateClass: org.quartz.impl.jdbcjobstore.StdJDBCDelegate 
org.quartz.jobStore.useProperties: false 
org.quartz.jobStore.dataSource: qzDS 
org.quartz.jobStore.tablePrefix: QRTZ_ 
org.quartz.jobStore.isClustered: false 

org.quartz.dataSource.qzDS.driver: com.mysql.jdbc.Driver 
org.quartz.dataSource.qzDS.URL: jdbc:mysql://localhost:3306/myschema 
org.quartz.dataSource.qzDS.user: myuser 
org.quartz.dataSource.qzDS.password: mypwd 
org.quartz.dataSource.qzDS.maxConnections: 5 

然后,我有一个简单的初始化类,几乎和Quartz发行版的example1一样, 其使用的未改性HelloJob来自相同例如:

public class NotificationInitializer { 

public void init(){ 
try { 
    SchedulerFactory schdFact = new StdSchedulerFactory("quartz.properties"); 
    Scheduler schd = schdFact.getScheduler(); 
    schd.start(); 

    JobDetail jd = new JobDetail("hellojob", Scheduler.DEFAULT_GROUP, HelloJob.class); 
    Trigger t = TriggerUtils.makeImmediateTrigger(2, 1000); 
    t.setStartTime(new Date()); 

    schd.scheduleJob(jd, t); 
    // wait long enough so that the scheduler as an opportunity to run 
    .......... 

    schd.shutdown(true); 
    } catch (SchedulerException e) { 
    ..... 
    } 
} 
} 

我也有一个简单的单元测试调用此类:

@RunWith(SpringJUnit4ClassRunner.class) 
@ContextConfiguration(locations = "classpath:spring/applicationContext.xml") 
public class NotificationInitializerTest { 
    private final static Logger logger = LoggerFactory 
     .getLogger(NotificationInitializerTest.class); 

    @BeforeClass 
    public static void setupClass() { 
     PropertyConfigurator.configure(Loader 
     .getResource("spring/log4j.properties")); 
     PropertyConfigurator.configure(Loader 
      .getResource("spring/quartz.properties")); 
    } 


    @Test 
    public void testInit() { 
     NotificationInitializer ni = new NotificationInitializer(); 
     ni.init(); 
     logger.info("NotificationInitializer.init() finished OK"); 
    } 

} 

当我运行这个单元测试我收到以下错误 - 请参见下面的完整的堆栈跟踪:org.springframework.beans.factory.BeanCreationException:

所致 错误创建名称为豆“org.springframework.jdbc.datasource.init.DataSour ceInitializer# 0': 调用init方法失败;嵌套的异常是com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: 查询是空的

任何想法出了什么问题?

此外,我现在设置JobStoreTX - 只是为了确保我可以得到它, 但最终我想使用JobStoreCMT toplug intoSpring的事务管理。 我找不到任何好的文档/示例如何做到这一点,特别是如果我不想使用 Spring的包装调度程序和硬编码所有触发器定义...

谢谢! Marina

java.lang.IllegalStateException: Failed to load ApplicationContext 
    at org.springframework.test.context.TestContext.getApplicationContext(TestContext.java:308) 
    at org.springframework.test.context.support.DependencyInjectionTestExecutionListener.injectDeendencies (DependencyInjectionTestExecutionListener.java:109) 
    at org.springframework.test.context.support.Dependenc yInjectionTestExecutionListener.prepareTestInstanc e(DependencyInjectionTestExecutionListener.java:75) 
    at org.springframework.test.context.TestContextManage r.prepareTestInstance(TestContextManager.java:333) 
    at org.springframework.test.context.junit4.SpringJUni t4ClassRunner.createTest(SpringJUnit4ClassRunner.j ava:220) 
    at 
    ..... 

Caused by: org.springframework.beans.factory.BeanCreationExce ption: Error creating bean with name 'org.springframework.jdbc.datasource.init.DataSour ceInitializer#0': Invocation of init method failed; nested exception is com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorEx ception: Query was empty 
    at org.springframework.beans.factory.support.Abstract AutowireCapableBeanFactory.initializeBean(Abstract AutowireCapableBeanFactory.java:1401) 
    at org.springframework.beans.factory.support.Abstract AutowireCapableBeanFactory.doCreateBean(AbstractAu towireCapableBeanFactory.java:512) 
    at org.springframework.beans.factory.support.Abstract AutowireCapableBeanFactory.createBean(AbstractAuto wireCapableBeanFactory.java:450) 
    at org.springframework.beans.factory.support.Abstract BeanFactory$1.getObject(AbstractBeanFactory.java:2 90) 
    at org.springframework.beans.factory.support.DefaultS ingletonBeanRegistry.getSingleton(DefaultSingleton BeanRegistry.java:222) 
    at org.springframework.beans.factory.support.Abstract BeanFactory.doGetBean(AbstractBeanFactory.java:287) 
    at org.springframework.beans.factory.support.Abstract BeanFactory.getBean(AbstractBeanFactory.java:189) 
    at org.springframework.beans.factory.support.DefaultL istableBeanFactory.preInstantiateSingletons(Defaul tListableBeanFactory.java:557) 
    at org.springframework.context.support.AbstractApplic ationContext.finishBeanFactoryInitialization(Abstr actApplicationContext.java:842) 
    at org.springframework.context.support.AbstractApplic ationContext.refresh(AbstractApplicationContext.ja va:416) 
    at org.springframework.test.context.support.AbstractG enericContextLoader.loadContext(AbstractGenericCon textLoader.java:84) 
    at org.springframework.test.context.support.AbstractG enericContextLoader.loadContext(AbstractGenericCon textLoader.java:1) 
    at org.springframework.test.context.TestContext.loadA pplicationContext(TestContext.java:280) 
    at org.springframework.test.context.TestContext.getAp plicationContext(TestContext.java:304) 
    ... 25 more 

Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorEx ception: Query was empty 
    at sun.reflect.NativeConstructorAccessorImpl.newInsta nce0(Native Method) 
    at sun.reflect.NativeConstructorAccessorImpl.newInsta nce(Unknown Source) 
    at sun.reflect.DelegatingConstructorAccessorImpl.newI nstance(Unknown Source) 
    at java.lang.reflect.Constructor.newInstance(Unknown Source) 
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:40 6) 
    at com.mysql.jdbc.Util.getInstance(Util.java:381) 
    at com.mysql.jdbc.SQLError.createSQLException(SQLErro r.java:1030) 
    at com.mysql.jdbc.SQLError.createSQLException(SQLErro r.java:956) 
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.ja va:3491) 
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.ja va:3423) 
    at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:19 36) 
    at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java :2060) 
    at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionIm pl.java:2536) 
    at com.mysql.jdbc.StatementImpl.executeUpdate(Stateme ntImpl.java:1564) 
    at com.mysql.jdbc.StatementImpl.executeUpdate(Stateme ntImpl.java:1485) 
    at org.apache.commons.dbcp.DelegatingStatement.execut eUpdate(DelegatingStatement.java:228) 
    at org.springframework.jdbc.datasource.init.ResourceD atabasePopulator.executeSqlScript(ResourceDatabase Populator.java:157) 
    at org.springframework.jdbc.datasource.init.ResourceD atabasePopulator.populate(ResourceDatabasePopulato r.java:110) 
    at org.springframework.jdbc.datasource.init.DataSourc eInitializer.afterPropertiesSet(DataSourceInitiali zer.java:69) 
    at org.springframework.beans.factory.support.Abstract AutowireCapableBeanFactory.invokeInitMethods(Abstr actAutowireCapableBeanFactory.java:1460) 
    at org.springframework.beans.factory.support.Abstract AutowireCapableBeanFactory.initializeBean(Abstract AutowireCapableBeanFactory.java:1398) 
    ... 
+0

你可以发布你的spring bean配置吗?在spring应用程序上下文加载时,是否使用脚本初始化quartz的DB? – blob

+0

是的,那是原因!看到我下面更详细的答案...谢谢! – Marina

回答

0

只有一个猜测:检查是否需要指定连接验证查询。喜欢的东西 validationQuery="select 1"

+0

谢谢,拉尔夫,我试过 - 并得到了同样的错误... – Marina

2

@blob:你是正确的目标。花了几个小时试图弄清楚为什么NotificationInitializer没有初始化(因为错误消息提示....)我终于尝试从我的Spring配置中删除Quartz DB初始化脚本 - 而且所有的工作都像一个魅力!

<jdbc:initialize-database data-source="dataSource" 
    enabled="${database.initschema}"> 
    <jdbc:script location="${database.schemaLoc}" /> 
    <jdbc:script location="${database.seedLoc}" /> 
    <!-- <jdbc:script location="classpath:db/tables_mysql_innodb_1.8.5.sql" /> --> 
</jdbc:initialize-database> 

我只是希望春天的错误消息是一个更具体一点... :)

现在,我还是不明白,为什么我不能创建数据库表中的石英这种方式 - 在同一脚本直接在数据库上运行时工作得很好。也许在Spring中有一些奇怪的启动动作序列?

感谢, 滨海

1

我最近碰到这个问题太,(我用的是Java7在Mac OS X),以下为我工作:

首先,测试方法是否java.net.InetAddress.getLocalHost()作品,如果它抛出异常,如:

Caused by: java.net.UnknownHostException: leo-mbp: nodename nor servname provided, or not known 
    at java.net.Inet6AddressImpl.lookupAllHostAddr(Native Method) 
    at java.net.InetAddress$1.lookupAllHostAddr(InetAddress.java:901) 
    at java.net.InetAddress.getAddressesFromNameService(InetAddress.java:1293) 
    at java.net.InetAddress.getLocalHost(InetAddress.java:1469) 

运行下面要解决它:

scutil --set HostName "localhost" 

希望对你有所帮助。

0

在quartz.properties文件中将“org.quartz.scheduler.instanceId”从AUTO更改为10。