what is the reason for the existence of the JAVA_HOME environment variable?
Asked Answered
G

8

112

Many java based application requires to set JAVA_HOME env variable. What's the purpose of this variable?

Glioma answered 24/2, 2011 at 8:18 Comment(4)
you can read hereGourd
I find the question has not an answer yet. As to execute java itself, it's not necessary to have this variable if you have the folder with the binary in the path. All answers point out the obvious: "Where java was installed". But Why: what is the meaning to running java applications?Ink
despite all these comments and answers, I see no actual reason to set this environment variable. No rationale. I came here from trying to set this with wsdl2java. If I wasn't using this tool, no need for the env variable....seemingly it's just that some tools use this var. but why?Miscreant
@Miscreant - I have not seen the reason stated anywhere explicitly, however. - JAVA_HOME is just convention. It doesn't have any special meaning other than everyone agreed to use it AFAIK - The only use I see is it gives tools the ability to differentiate between the JRE which is normally set in the PATH variable and the JDK. Normally the JAVE_HOME is set to the JDK. - It's explicit. There is no dealing with the order of directories like you have with PATH where there could be multiple places to find java exe.Demasculinize
G
24

The purpose is to point to where Java is installed. $JAVA_HOME/bin/java should execute the Java runtime.

Grocery answered 24/2, 2011 at 8:21 Comment(4)
But it is stupid, because java should be in the path, and the binary can locate itself and open the other files using a relative path.Whitish
It's useful when java is not on $PATH, for example when you have multiple SDK installations.Grocery
The 1st argument to the binary is the full name of the executable itself, java doesn't need to be in the path to find its own directory.Whitish
@Grocery As someone trying to set up multiple JDKs, why would you not want java on the path? How does Windows locate java from java_home anyway? I thought the path was more or less defined as "the list of places the OS will look for executables".Quell
S
22

Environment variables are strings that contain information such as drive, path, or file name.

The JAVA_HOME environment variable points to the directory where the Java runtime environment (JRE) is installed on your computer.

Sulfonation answered 24/2, 2011 at 8:23 Comment(3)
One correction: JAVA_HOME should point to a JDK not a JRE. Many apps don't care about the difference but it is significant for some.Enravish
There is also JRE folder available in the JDK. Hence, with the help of JAVA_HOME , an application can locate JDK as well as JRE.Contorted
@ChrisNava: Seem that pointing JAVA_HOME to a JRE installation is valid in some cases (most non-development cases I would guess): #17602327. So saying "should" is saying too much.Northcutt
H
8

When you run a Java program you need to first start the JVM, typically this is done by running an executable, on Windows this is java.exe. You can get that in lots of ways for example just giving a full path:

C:\somedir\bin\java.exe

or may having it on your PATH.

You specify as command line arguments some class files or Jar files containing class files which are your program. But that's not enough, the java.exe itself needs various other resources, not least all the Java libraries. By setting the environment variable JAVA_HOME you specify where the JRE, and hence all those runtime resources, are to be found. You should ensure that the particular Java you execute matches the setting of JAVA_HOME.

You may also need to put JAVA_HOME\bin early on your path so that if the java.exe spawns a copy of itself (for example to compile a JSP) it picks up the right version.

Hundredfold answered 24/2, 2011 at 9:6 Comment(0)
T
8

According to @dirai here JAVA_HOME is not used by Java itself but by some third party tools like for instance Apache Tomcat. Most applications however will work without this variable being set but some could show unexpected behaviour.

Trippet answered 22/9, 2019 at 5:7 Comment(0)
E
5

JAVA_HOME is an environment variable.

It has to be setup on different operating system. Check out the following links.

Also see here for more information.

Expansion answered 24/2, 2011 at 13:32 Comment(3)
You are conflating environment with path, which are different things but used in Windows exactly the same way as in Linux.Eloquent
@val just pointing out, that has since been corrected in his answer.Theis
Just to add to the list JAVA_HOME in Windows 10Sweetscented
H
5

JAVA_HOME allows you to run any of multiple java installations. Even if you have the /usr/lib/jvm/java-1.8.0/bin/java in your PATH first, it's useful to be able to say JAVA_HOME=/usr/lib/jvm/java-1.5.0 and have the default "java" with which you run programs use the other one, instead, as a matter of an environment setting. This allows a programmer to use the java they need, even if it's not installed in a normal system location, and test or provide reverse compatibility with that alternate version. And it's not vulnerable to being reset in the PATH by another installed program, such as a major version update for java itself.

Hobby answered 7/2, 2018 at 0:55 Comment(0)
H
2

To understand the purpose of JAVA_HOME environment variable, you need to first understand which programs look for and read this variable value. Some examples are: Apache Tomcat, Apache Maven, Gradle, Jenkins etc. If you notice, most of these are development tools and that's why mostly JAVA_HOME is set to point to JDK instead of JRE.

Consumer facing Java applications don't read JAVA_HOME variable and they just need to know where the JVM is located and that's why JVM location (directory) needs to be added to the PATH variable. This is automatically done for you when you install Java software. Whenever you try to run a Java application by either double clicking on the app or through command line, your operating system reads PATH variable to locate and run JVM and it doesn't look for JAVA_HOME variable.

Henryson answered 26/6, 2022 at 15:41 Comment(0)
G
-1

JAVA_HOME is used in MacOS to determine which JRE to use when you are trying to launch java, javac, etc. java executable on PATH is just a proxy which then launches java from JAVA_HOME

Girvin answered 7/3, 2023 at 14:46 Comment(1)
WHat about windows?Attached

© 2022 - 2024 — McMap. All rights reserved.