`

jdk的安装过程 注册表中的信息

    博客分类:
  • jdk
jdk 
阅读更多
JDK在安装的过程当中将会生成如下3个项目:

HKEY_LOCAL_MACHINE/SOFTWARE/JavaSoft/Java Development Kit HKEY_LOCAL_MACHINE/SOFTWARE/JavaSoft/Java Plug-in HKEY_LOCAL_MACHINE/SOFTWARE/JavaSoft/Java Runtime Environment

(我的注册表下还有2个javaupdate和javawebstart)      

  同时,JDK安装程序将会把java.exe,javaw.exe,javareg.exe这3个可执行文件拷贝到winnt/system32目录下,由于 winnt/system32被操作系统缺省的设置为最高优先权的PATH搜索路径,因此可保证用户在命令行任何目录下可运行java.exe来启动 JVM。

    java.exe在启动时是通过下面方式来确定的: 假如存在../jre/bin/java.dll文件,则查找../jre/lib/ jvm.cfg文件,在该文件中,第1个被列出的jvm.dll类型作为缺省值(假如在java.exe命令行指定了jvm.dll的类型,则使用指定类型)。jvm.dll类型分为hotspot,classic,server三种。假如不存在../jre/lib/jvm.cfg文件,则打印你说的错误信息: 如不存在../jre/bin/java.dll(当运行的是winnt/system32/java.exe),则注册表将在此时发挥作用, HKEY_LOCAL_MACHINE/SOFTWARE/JavaSoft/Java Runtime Environment/ CurrentVersion键值所记录的实际上是winnt/system32/java.exe的版本值,该版本值只保存主、次两个版本号,如 1.2,1.3等。 同时java.exe程序内部本身也有一个标识自身的版本值,如1.2、1.3等。java.exe根据自己内部的版本值和CurrentVersion值相比较,如果发现两个值相等,则将在HKEY_LOCAL_MACHINE/SOFTWARE/ JavaSoft/Java Runtime Environment/MainVersion.MicroVersion项下获取JRE所在目录及动态链接库,这两个键的名称分别是JavaHome 和RuntimeLib,MainVersion表示主版本号,MicroVersion表示次版本号。

        如果java.exe内部版本值和CurrentVersion不一致,则报类似以下的错误: Registry key 'Software/JavaSoft/Java Runtime Environment/CurrentVersion' has value '1.2', but '1.3' is required. 意思是说,注册表当前所记载的winnt/system32/java.exe版本为1.2,但是此时运行的java.exe版本为1.3。 java.exe抱怨除非注册表有1.3版的记载,否则自己无法正确定位JRE目录和jvm.dll,因此提示1.3是需要的。 这里,我们不能简单的修改注册表的CurrentVersion值来达到这个目的。

     一般地,当在系统中装了两套版本的Java2 SDK(如先装1.2而后又装了1.3),后面安装的Java2 SDK会将自己带的java.exe和javaw.exe拷贝到winnt/system32目录下,从而覆盖先前版本的java.exe和 javaw.exe,并且在注册表中改写CurrentVersion为1.3。所以建议在安装Java2 SDK前,先卸载以前安装的版本。如果人为的修改CurrentVersion,会使得不同版本的java.exe加载与己版本不符的java.dll及 jvm.dll,将引起难以预料的后果!

     特殊情况:

    JBuilder自己带一套JDK,在JBuilder安装完成后,JBuilder安装程序会修改CurrentVersion为自己所带JDK的版本,但不会覆盖winnt/system32下的java.exe和javaw.exe。

    WebLogic自己带一套JDK,在WebLogic安装完成后,WebLogic安装程序不会修改注册表,也不会覆盖winnt/system32下的java.exe和javaw.exe。

    Oracle自己带一套JDK(一般是比较低版本的,例如8.1.7仅仅带JDK 1.1.7),在Oracle安装完成后,Oracle安装程序不会修改注册表,也不会覆盖winnt/system32下的java.exe和 javaw.exe。但是,Oralce安装程序会修改系统PATH变量,将自带的JRE的bin路径加入其中,且置于最前面。随着Oracle安装版本的不同,其自带JRE的JVM启动程序也不同。在笔者机器上安装的Oracle 8.1.7,其JRE就装在C:/Program Files/Oracle下,并将C:/Program Files/Oracle/jre/1.1.7/bin放在PATH变量最前,其JVM启动程序是jre.exe而非java.exe。 以上就是Java2 SDK在Windows下安装时所做的动作,这样会带来兼容性问题.

   问题背景:安装Java2 SDK后,安装了JBuilder6,未修改任何PATH变量

  问题1 当在操作系统中安装了JDK 1.2,其后安装了JBuilder6(自带JDK 1.3.1),这时CurrentVersion为1.3,在命令行执行java -version时,提示: Registry key 'Software/JavaSoft/Java Runtime Environment/CurrentVersion' has value '1.3', but '1.2' is required. 解决方法:将JDK 1.2中java.exe所在路径加入到操作系统PATH的首位,从而保证在命令行调用java时总是执行JDK 1.2中的java.exe,以使得java.exe可正确定位JRE和jvm.dll。

问题2 当在操作系统中安装了JDK 1.3.0,而后安装了JBuilder6(自带JDK 1.3.1),这时CurrentVersion为1.3,但是此1.3是指向的是JBuilder6自带的JDK 1.3.1的JRE,而非指向先前JDK 1.3.0的JRE,当在命令行执行java -version时,此时执行的是JDK 1.3.0拷贝到winnt/system32的一个java.exe副本,但打印的版本信息却是: java version "1.3.1" Java(TM) 2 Runtime Environment, Standard Edition (build 1.3.1-b24) Java HotSpot(TM) Client VM (build 1.3.1-b24, mixed mode) 导致该问题的原因是java.exe只维护小数点后1位的版本号,而非2位。 解决方法:同问题1

  问题3: 如果在操作系统中先安装了JDK 1.3.0,而后安装了带有与安装JDK主次版本相同的JBuilder6(带JDK 1.3.1,前两位相同),则问题1实际上被隐蔽了,没有发生的机会;而问题2的隐蔽性也很强,不容易发觉,因为人们往往会忽略JDK的第3个版本号。 如问题2所叙,在命令行执行java,虽然是使用JDK 1.3.0的一个java.exe副本(winnt/system32目录下),而实际上却是使用JBuilder6下JDK 1.3.1的JRE及其目录结构,其结果是当我们使用Java2的extension mechanism将jar文件放到JDK 1.3.0的jre/lib/ext目录下时,发现达不到希望的效果 – 在命令行用java启动程序时,不会自动去JDK 1.3.0的jre/lib/ext目录下去搜索jar文件,它只会去JBuilder6下JDK 1.3.1的jre/lib/ext去搜索jar文件,而JBuilder6下的JDK 1.3.1并不存在jre/lib/ext这么一个目录! 问题3极为隐蔽,除非完全对Java2 SDK的安装及class定位机制了解,一般的开发者是难以发现问题所在的。有关Java2中class定位机制,见《Java2中的class定位机制》一文。

    事实上,即使仅仅在系统中存在一份JDK 1.3.0,如果在命令行运行java的话,使用的JRE目录是C:/Program Files/JavaSoft/JRE/1.3,也就是说,即使我们在c:/jdk1.3/jre/lib/ext下放置我们的extension jar,也得不到预期的结果。正确的做法是放在C:/Program Files/JavaSoft/JRE/1.3/lib/ext目录下。

解决方法:同问题1 综上所叙,强烈建议将%JDK_HOME%/bin目录放在Windows操作系统的PATH变量的首位,以避免潜在的问题。

我先安装了1.5然后有安装了1.6 后来把1.6的文件给删除了,导致java命令报错,用上面的方法将%JDK_HOME%/bin目录放在Windows操作系统的PATH变量的首位,就不会出现说找不到jvm.cfg等问题了.
分享到:
评论

相关推荐

    修改有关jdk配置的注册表文件

    这个文件本质上是一个导入向导,可以将其中包含的注册表设置导入到你的Windows注册表中。 3. 使用"regedit.exe",即Windows的注册表编辑器,通常位于"C:\Windows"目录下。运行这个程序需要管理员权限,因此在执行前...

    jdk注册表任何版本

    JDK在安装时会在注册表中创建条目,以便系统能够识别和管理Java环境,包括JRE(Java Runtime Environment)的路径、版本信息、默认设置等。这些注册表项对于Java应用程序的正常运行至关重要。 描述中提到的"...

    jdk1.8安装版64位和安装教程

    6. **配置环境变量**: 安装过程中,可以选择自动配置环境变量,包括`JAVA_HOME`、`PATH`和`CLASSPATH`。如果未自动配置,需要手动添加。 ### 环境变量配置 环境变量配置是确保JDK正确工作的重要环节。文件"环境...

    jdk1.8免安装

    标题“jdk1.8免安装”指的是Java Development Kit(JDK)的1.8版本的一个特殊构建,它是为Windows操作系统设计的绿色版本,无需进行传统的安装过程。这种免安装版本通常是为了方便用户快速部署和使用,尤其是对于...

    jdk1.7 及安装教程 环境配置卸载工具.zip

    安装过程中,可以选择默认安装路径或者自定义安装位置。 3. **配置环境变量**:安装完成后,需要配置系统环境变量。这包括设置`JAVA_HOME`指向JDK的安装目录,将`%JAVA_HOME%\bin`添加到`PATH`变量中,这样命令行...

    如何完全卸载JDK

    此方法不仅包括删除安装路径下的文件,还包括清除注册表中的相关条目,确保所有与JDK相关的痕迹都被清除。 1. **卸载JDK程序** 首先通过控制面板中的“卸载程序”功能来卸载JDK。打开控制面板,找到“程序和功能...

    (JDK大全) jdk1.6.0_24 解压免安装版

    对于开发者而言,它省去了安装过程中可能遇到的权限问题或系统冲突,特别适合于那些不希望在系统注册表中留下痕迹或者频繁切换不同JDK版本的场景。只需将压缩包解压到指定位置,设置环境变量`JAVA_HOME`指向JDK的...

    jdk 1.8 绿色版

    3. **不修改系统注册表**:传统的JDK安装可能会对系统注册表进行修改,而绿色版JDK则不会对系统注册表进行任何更改,减少了潜在的安全风险。 4. **环境变量配置简单**:虽然绿色版JDK不需要复杂的安装步骤,但为了...

    非安装jdk1.4.2.rar

    通常,安装版的软件会将所有必要的文件和配置信息写入系统注册表或其他特定位置,而“非安装版”或“便携版”的JDK则将所有文件打包在一个压缩文件中,用户只需解压到任意目录,然后设置环境变量就可以使用,这种...

    JDK安装与配置[整理].pdf

    安装过程中可能会有安全软件发出警告,需允许修改注册表信息。 安装完成后,为了使系统能够识别和执行Java程序,还需要配置环境变量: - **JAVA_HOME**:这个环境变量应指向JDK的安装目录,例如E:\java\jdk1.6.0_...

    nsis web项目 打包安装文件exe,jdk、tomcat设置

    6. **注册表操作**:可能需要在注册表中添加条目,以帮助操作系统识别安装的JDK和Tomcat。 7. **启动菜单快捷方式**:为方便用户,可以在开始菜单创建JDK的控制台和Tomcat的服务管理快捷方式。 8. **结束提示**:...

    彻底卸载jdk

    - 在列出的所有已安装程序中,找到所有与JDK相关的条目,这通常会显示为“Java Development Kit”或者带有版本号的名称,如“Java SE Development Kit 8”。 - 选中JDK的条目,点击“卸载”按钮,按照提示完成卸载...

    jdk8绿色免安装64位

    通常,安装一个软件会涉及注册表修改、系统路径设置等一系列步骤,而绿色版则避免了这些过程。它通常是一个压缩文件,解压后即可使用,便于携带和在不同计算机上快速部署,且不会对系统造成过多影响。 对于64位版本...

    jdk-7u80-windows-x64.zip绿色免安装

    本篇文章将详细解析"jdk-7u80-windows-x64.zip"这个绿色免安装版的JDK,它专为Windows 64位系统设计,旨在提供便捷的开发环境,无需复杂的安装过程。 一、JDK 7u80概述 JDK 7u80是Java 7的第80个更新版本,它包含了...

    jdk1.6解压版(免安装版)

    在给定的"jdk1.6解压版(免安装版)"中,用户无需经历传统意义上的安装过程,只需将压缩包解压到指定位置,然后配置系统环境变量,就可以开始使用这个版本的JDK进行Java程序的开发和运行。 1. **JDK1.6**:这是Java的...

    jdk11绿色解压版win10win7

    这种类型的软件避免了传统安装过程可能带来的系统注册表污染,易于备份和迁移,且对系统的依赖性较低。JDK11绿色解压版同样具备这些特性,用户只需下载对应版本的压缩包,解压后即可开始使用。 JDK11是Oracle公司...

    jdk1.6免安装纯绿色版

    在这个场景中,我们关注的是JDK 1.6.0_39的32位免安装绿色版,这是一款特别适合那些希望快速在系统上启动并运行Java环境,而无需经历传统安装过程的用户。 首先,"免安装版"或"绿色版"通常指的是不需要通过标准安装...

    Centos6下JDK的安装

    4. **配置环境变量**:这是安装JDK后的重要步骤,因为Linux系统不像Windows有注册表,因此需要通过环境变量来指示系统JDK的安装位置。首先,找到JDK的安装路径,通常位于`/usr/java`目录下。使用`vim /etc/profile`...

    jdk6绿色免安装版

    1. **便携性**:绿色免安装版无需正式的安装过程,只需解压缩到任意目录,减少了对系统注册表的依赖,使得在不同计算机间移动和备份变得简单。 2. **快速部署**:由于不需要执行安装程序,可以快速在任何支持的系统...

    解压版jdk1.8,无需安装

    解压版的JDK1.8适用于那些不希望在系统注册表中留下痕迹或不想进行繁琐安装步骤的用户。只需将压缩包解压到任何位置,然后将`bin`目录添加到系统环境变量`PATH`中,即可在命令行中使用Java工具。这种便携式版本尤其...

Global site tag (gtag.js) - Google Analytics