在Linux部署项目时,jdk的问题
2009-10-30 09:53
453 查看
一般在linux上部署项目时,直接把在window上编译出来的jar文件部署上去,再运行就可以了,但是今天碰到的问题 :
Exception in thread "main" java.lang.NoClassDefFoundError: DataServer
at gnu.java.lang.MainThread.run(libgcj.so.7rh)
Caused by: java.lang.ClassNotFoundException: DataServer not found in gnu.gcj.runtime.SystemClassLoader{urls=[file:./,file:/root/test/jar/dom4j-1.6.1.jar,file:/root/test/jar/jaxen-1.1-beta-6.jar,file:/root/test/jar/log4j-1.2.15.jar], parent=gnu.gcj.runtime.ExtensionClassLoader{urls=[], parent=null}}
at java.net.URLClassLoader.findClass(libgcj.so.7rh)
at gnu.gcj.runtime.SystemClassLoader.findClass(libgcj.so.7rh)
at java.lang.ClassLoader.loadClass(libgcj.so.7rh)
at java.lang.ClassLoader.loadClass(libgcj.so.7rh)
at gnu.java.lang.MainThread.run(libgcj.so.7rh)
原因:不是版本的原因,虽然运行时环境和编译时环境版本不一致通常会导致一些问题,但我觉得不是你这个问题的关键所在。关键是Class文件的格式不能被识别
每一个JAVA Class文件的前4个字节被称为他的魔数(magic number):0XCAFEBABE。魔数的作用在于,可以轻松地分辨出Java Class文件和非Java Class文件。在Class文件的接下来的4个字节包含主、次版本号。当你用javac 编译一个java源程序为Java Class文件的时候,Javac 会把其主、次版本写入class文件指定的位置中。当你用java ClassFile运行你的Java Class文件的时候,运行时会判断该Class的主、次版本
基于向下兼容的原则,你用低版本的javac编译的Class文件可以在高版本的运行时环境中运行;但是反过来,你用高版本的javac编译的Class文件不可以在低版本的运行时环境中运行,即使你没有用到低版本不支持的高版本新加入的特性,Java运行时会给用户提供详细的错误报告,内容应该是NotSupportedVersion之类的(请参考Java API的说明)
1. 用1.5.0.7编译时环境编译,用1.5.0.7运行时环境运行
-bash-3.00$ pwd
/home/a/u/wuqingping/testpro
-bash-3.00$ more HelloWorld.java
public class HelloWorld
{
public static void main(String args[]) throws Exception
{
System.out.println("Hello World!");
}
}
-bash-3.00$ javac HelloWorld.java
-bash-3.00$ java HelloWorld
Hello World!
-bash-3.00$ java -version
java version "1.5.0_07"
Java(TM) 2 Runtime Environment, Standard Edition (build 1.5.0_07-b03)
Java HotSpot(TM) Server VM (build 1.5.0_07-b03, mixed mode)
-bash-3.00$
2. 用1.5.0.7运行时环境运行用1.4.2.12编译时环境编译的Class文件
-bash-3.00$ /usr/jdk/j2sdk1.4.2_12/bin/java -version
java version "1.4.2_12"
Java(TM) 2 Runtime Environment, Standard Edition (build 1.4.2_12-b03)
Java HotSpot(TM) Client VM (build 1.4.2_12-b03, mixed mode)
-bash-3.00$ /usr/jdk/j2sdk1.4.2_12/bin/java HelloWorld
Exception in thread "main" java.lang.UnsupportedClassVersionError: HelloWorld (Unsupported major.minor version 49.0)
at java.lang.ClassLoader.defineClass0(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:539)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:123)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:251)
at java.net.URLClassLoader.access$100(URLClassLoader.java:55)
at java.net.URLClassLoader$1.run(URLClassLoader.java:194)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:187)
at java.lang.ClassLoader.loadClass(ClassLoader.java:289)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:274)
at java.lang.ClassLoader.loadClass(ClassLoader.java:235)
at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:302)
-bash-3.00$
3. 用1.4.2.12编译时环境编译,分别用1.4.2.12运行时环境和1.5.0.7运行时环境运行
-bash-3.00$ /usr/jdk/j2sdk1.4.2_12/bin/javac HelloWorld.java
-bash-3.00$ /usr/jdk/j2sdk1.4.2_12/bin/java HelloWorld
Hello World!
-bash-3.00$ java -version
java version "1.5.0_07"
Java(TM) 2 Runtime Environment, Standard Edition (build 1.5.0_07-b03)
Java HotSpot(TM) Server VM (build 1.5.0_07-b03, mixed mode)
-bash-3.00$ java HelloWorld
Hello World!
Exception in thread "main" java.lang.NoClassDefFoundError: DataServer
at gnu.java.lang.MainThread.run(libgcj.so.7rh)
Caused by: java.lang.ClassNotFoundException: DataServer not found in gnu.gcj.runtime.SystemClassLoader{urls=[file:./,file:/root/test/jar/dom4j-1.6.1.jar,file:/root/test/jar/jaxen-1.1-beta-6.jar,file:/root/test/jar/log4j-1.2.15.jar], parent=gnu.gcj.runtime.ExtensionClassLoader{urls=[], parent=null}}
at java.net.URLClassLoader.findClass(libgcj.so.7rh)
at gnu.gcj.runtime.SystemClassLoader.findClass(libgcj.so.7rh)
at java.lang.ClassLoader.loadClass(libgcj.so.7rh)
at java.lang.ClassLoader.loadClass(libgcj.so.7rh)
at gnu.java.lang.MainThread.run(libgcj.so.7rh)
原因:不是版本的原因,虽然运行时环境和编译时环境版本不一致通常会导致一些问题,但我觉得不是你这个问题的关键所在。关键是Class文件的格式不能被识别
每一个JAVA Class文件的前4个字节被称为他的魔数(magic number):0XCAFEBABE。魔数的作用在于,可以轻松地分辨出Java Class文件和非Java Class文件。在Class文件的接下来的4个字节包含主、次版本号。当你用javac 编译一个java源程序为Java Class文件的时候,Javac 会把其主、次版本写入class文件指定的位置中。当你用java ClassFile运行你的Java Class文件的时候,运行时会判断该Class的主、次版本
基于向下兼容的原则,你用低版本的javac编译的Class文件可以在高版本的运行时环境中运行;但是反过来,你用高版本的javac编译的Class文件不可以在低版本的运行时环境中运行,即使你没有用到低版本不支持的高版本新加入的特性,Java运行时会给用户提供详细的错误报告,内容应该是NotSupportedVersion之类的(请参考Java API的说明)
1. 用1.5.0.7编译时环境编译,用1.5.0.7运行时环境运行
-bash-3.00$ pwd
/home/a/u/wuqingping/testpro
-bash-3.00$ more HelloWorld.java
public class HelloWorld
{
public static void main(String args[]) throws Exception
{
System.out.println("Hello World!");
}
}
-bash-3.00$ javac HelloWorld.java
-bash-3.00$ java HelloWorld
Hello World!
-bash-3.00$ java -version
java version "1.5.0_07"
Java(TM) 2 Runtime Environment, Standard Edition (build 1.5.0_07-b03)
Java HotSpot(TM) Server VM (build 1.5.0_07-b03, mixed mode)
-bash-3.00$
2. 用1.5.0.7运行时环境运行用1.4.2.12编译时环境编译的Class文件
-bash-3.00$ /usr/jdk/j2sdk1.4.2_12/bin/java -version
java version "1.4.2_12"
Java(TM) 2 Runtime Environment, Standard Edition (build 1.4.2_12-b03)
Java HotSpot(TM) Client VM (build 1.4.2_12-b03, mixed mode)
-bash-3.00$ /usr/jdk/j2sdk1.4.2_12/bin/java HelloWorld
Exception in thread "main" java.lang.UnsupportedClassVersionError: HelloWorld (Unsupported major.minor version 49.0)
at java.lang.ClassLoader.defineClass0(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:539)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:123)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:251)
at java.net.URLClassLoader.access$100(URLClassLoader.java:55)
at java.net.URLClassLoader$1.run(URLClassLoader.java:194)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:187)
at java.lang.ClassLoader.loadClass(ClassLoader.java:289)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:274)
at java.lang.ClassLoader.loadClass(ClassLoader.java:235)
at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:302)
-bash-3.00$
3. 用1.4.2.12编译时环境编译,分别用1.4.2.12运行时环境和1.5.0.7运行时环境运行
-bash-3.00$ /usr/jdk/j2sdk1.4.2_12/bin/javac HelloWorld.java
-bash-3.00$ /usr/jdk/j2sdk1.4.2_12/bin/java HelloWorld
Hello World!
-bash-3.00$ java -version
java version "1.5.0_07"
Java(TM) 2 Runtime Environment, Standard Edition (build 1.5.0_07-b03)
Java HotSpot(TM) Server VM (build 1.5.0_07-b03, mixed mode)
-bash-3.00$ java HelloWorld
Hello World!
相关文章推荐
- linux下部署项目后可能出现的问题 ;(是无效,Web server process 写入资料的目录)
- linux下部署web项目遇到的问题
- linux部署项目所遇到的问题
- linux部署项目tomcat不生成log4j日志问题
- LINUX部署WEB项目(JDK安装和配置)
- LINUX部署WEB项目(JDK安装和配置)
- intellij idea2016 linux springboot项目下解决热部署问题
- linux jdk+mysql+tomcat+nginx 项目部署步骤
- 解决linux部署项目后,第一次访问初始化数据源的时候很慢的问题
- java的maven工程部署到linux(包括tomcat部署,jdk安装,maven工程打包及项目运行)
- LINUX部署WEB项目(JDK安装和配置)
- 阿里云服务器linux环境,从启动tomcat服务器外网访问--->绑定域名--->Navicat远程连接mysql--->阿里云服务器部署项目过程中,一定会遇到的五大问题;
- Linux+Xshell+Xftp+tomcat+jdk部署javaWeb项目
- linux下jdk、tomcat的安装及项目的部署和去掉项目名访问详细总结
- 项目部署时一些常见linux命令和遇到的问题
- Linux下was上部署项目遇到的问题
- linux部署web项目不能直接访问80端口的问题
- linux部署JavaWeb项目及启动项目常见问题
- LINUX部署WEB项目(JDK安装和配置)
- linux 项目部署问题