关闭

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

发表于:2014-5-16 10:26

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:trampwind    来源:51Testing软件测试网采编

  写了一个简单的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  后,再次执行计划任务则执行成功。
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号