qileilove

blog已经转移至github,大家请访问 http://qaseven.github.io/

JAVA程序在windows计划任务里执行的问题

 写了一个简单的JAVA类,定时从一个ORACLE数据库取数据放到另一个mysql数据库中,写了一个脚本如下:
set classpath=.;%classpath%;./classes12.jar;./mysql-connector-java-5.1.6-bin.jar;E:\workfile\SAP-to-MYSQL\getsapdata.class
set path=%path%;D:\develop\Java\jdk1.6\bin
set JAVA_HOME=D:\develop\Java\jdk1.6
cd  E:\workfile\SAP-to-MYSQL
java getsapdata >>getsapdata.log
  手动执行的时候完全没有问题,当时加到windows计划任务里就是执行不成功,程序执行的DOS窗口一闪而过,也看不到是什么错误,网上搜了半天,也没找到可行的答案,后来在脚本里加入了延迟语句 ping -n 5 127.1>nul,才看到报的是找不到类的错误:
Exception in thread "main" java.lang.NoClassDefFoundError: getsapdata
Caused by: java.lang.ClassNotFoundException: getsapdata
at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301
at java.lang.ClassLoader.loadClass(ClassLoader.java:248)
Could not find the main class: getsapdata.  Program will exit.
  明明就在这个目录下,怎么就找不到呢,迷惑,又是一阵搜索,还是没答案,想着难道windows定时任务挑分区吗,就把程序挪到C盘,结果计划任务真的执行成功了,那是怎么回事呢,想想找不到类怎么也应该是环境变量路径类的问题吧,后来想到我以前经常用DOS窗口敲命令,打开DOS窗口默认在C盘,而我的应用一般都在其他分区,所以每次敲命令比如:cd e:\work\shell,运行完后当前路径并没有改变,必须再敲一下e:,才进入到e:\work\shell目录,会不会是windows计划任务开启DOS执行窗口也是默认在C盘,我虽然在脚本里加了 cd  E:\workfile\SAP-to-MYSQL命令,但实际上系统的当前路径还是会在默认的C:\Users\Administrator 目录下,我的程序移动到C盘的时候,因为系统默认路径也在C盘,所以 cd  命令是成功进入了c盘的我的应用程序目录,但不是C盘的就不行了,网上查了下,原来cd 的时候加个 /d 参数可以直接改变盘符,哎,以前居然一致没用过,把脚本中的 cd 命令改为 cd /d E:\workfile\SAP-to-MYSQL  后,再次执行计划任务则执行成功。

posted on 2014-05-19 10:16 顺其自然EVO 阅读(922) 评论(0)  编辑  收藏


只有注册用户登录后才能发表评论。


网站导航:
 
<2014年5月>
27282930123
45678910
11121314151617
18192021222324
25262728293031
1234567

导航

统计

常用链接

留言簿(55)

随笔分类

随笔档案

文章分类

文章档案

搜索

最新评论

阅读排行榜

评论排行榜