-
Notifications
You must be signed in to change notification settings - Fork 446
JDK Requirements
vscode-java requires a Java Development Kit to run.
Since vscode-java 1.2.0, it publishes platform specific versions to Microsoft VS Code marketplace. The platform versions have JRE 21 embedded in Java extension for platforms such as win32-x64
, linux-x64
, linux-arm64
, darwin-x64
, darwin-arm64
. The embedded JRE will be used to launch the Java Language Server by default. Users are only responsible for configuring Project JDKs to compile your Java projects. For example, if you are working on JDK 8, you only need to install JDK 8 and no longer need to install JDK 21 additionally.
However, if you want to use a different JDK to start the Java Language Server, you can use the setting java.jdt.ls.java.home
to do so.
For some other extension marketplaces (e.g. Open VSX), they haven't supported platform specific versions yet and will still use the universal version without embedded JRE.
In the universal version, the path to the Java Development Kit is searched in the following order:
- the
java.jdt.ls.java.home
setting in VS Code settings (workspace then user settings) - (deprecated, use
java.jdt.ls.java.home
instead). thejava.home
setting in VS Code settings (workspace then user settings) - the
JDK_HOME
environment variable - the
JAVA_HOME
environment variable - on the current system path
Note: The path should end at the parent folder that contains the bin
folder.
Example Path: Use /usr/lib/jvm/java-21
if bin
exists at /usr/lib/jvm/java-21/bin
.
This JDK will be used to launch the Java Language Server. by default, will be used to compile your projects.
If you need to compile your projects against a different JDK version, it's recommended you configure the java.configuration.runtimes
property in your user settings, eg:
"java.configuration.runtimes": [
{
"name": "JavaSE-1.8",
"path": "/path/to/jdk-8",
},
{
"name": "JavaSE-11",
"path": "/path/to/jdk-11",
},
{
"name": "JavaSE-17",
"path": "/path/to/jdk-17",
"default": true
},
]
The default runtime will be used when you open standalone Java files.
⚠ For the universal version, simply defining JavaSE-21 in java.configuration.runtimes
is not enough for vscode-java to start, java.jdt.ls.java.home
(or any of its alternative environment variables) still needs to point to a valid JDK 21 location.
This applies mainly to the Universal Version.
The Eclipse project has begun to require Java 21 as the minimum required version for running the platform for Eclipse SDK 4.35 (2025-03). The m2e team has also done the same for its November 2024 release. We use m2e core components to provide Maven support for the Java language server (Eclipse JDT.LS). This requires the entire language server to run on a minimum of Java 21.
Because vscode-java depends on the Eclipse JDT.LS, the same requirement applies to vscode-java but on a more agressive timeline: vscode-java usually consumes JDT.LS builds that depend on bleeding edge JDT features, effectively shipping pre-release versions of Eclipse Platform/JDT. As of January 9, 2025, Java 21 will be required for running all new releases (eg. >= 1.39.0 and existing pre-relases) of vscode-java.
NO you don't! Well you should, be we're not here to judge. It is still possible to compile/run Java applications from Java 1.8 to 22, provided the proper java.configuration.runtimes
are configured in the user's settings.json.
You can set the java.import.gradle.java.home
preference to specifically run the Gradle Daemon using a prior version of Java. However, this only works for Gradle >= 4.7.