JAVA程序在windows计划任务里执行的问题
2014-05-15 08:40
369 查看
写了一个简单的JAVA类,定时从一个ORACLE数据库取数据放到另一个mysql数据库中,写了一个脚本如下:
set classpath=.;%classpath%;./classes12.jar;./mysql-connector-java-5.1.6-bin.jar
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 后,再次执行计划任务则执行成功。
set classpath=.;%classpath%;./classes12.jar;./mysql-connector-java-5.1.6-bin.jar
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 后,再次执行计划任务则执行成功。
相关文章推荐
- JAVA程序在windows计划任务里执行的问题
- Windows 2008 r2任务计划程序执行批处理失败问题解决方法
- windows计划任务后台定时执行java的jar文件
- 在Windows 任务计划程序中执行powershell脚本
- windows计划任务后台定时执行java的jar文件
- crontab定时任务Java程序不执行问题
- windows 任务计划程序执行 bat ,重启服务
- windows计划任务执行php程序
- Windows计划任务执行时不显示窗口的问题
- Windows 任务计划 定时重复执行程序
- 在WINDOWS任务计划程序下执行PHP文件 PHP定时功能的实现
- windows 2008的计划任务执行问题
- Windows计划任务执行时不显示窗口的问题
- python脚本在Windows计划任务执行问题
- windows环境下使用命令行执行java程序输出文件编码问题
- 在WINDOWS任务计划程序下执行PHP文件 PHP定时功能的实现
- 在WINDOWS任务计划程序下执行PHP文件 PHP定时功能的实现
- WINDOWS 任务计划 循环执行某程序的任务计划设置
- Windows 任务计划程序定时执行 powershell 脚本
- Windows 任务计划执行Python程序的设置