Liberica JDK 17.0.7+7 Install Guide


Introduction

This guide describes how to install the Liberica product on Microsoft Windows, Linux, and macOS computers. The type of installation you choose depends on your requirements and the platform you use.

There are several Liberica distribution variants:

  • JDK Standard — use it to run, compile, and debug applications or create your own Java Runtime with a subset of Java modules;
  • JDK Full — includes LibericaFX and an extended set of VMs;
  • JDK Lite — install it if you are looking for a smaller footprint, yet fully functional JDK;
  • JRE Standard — use it to run Java applications;
  • JRE Full — includes LibericaFX and an extended set of VMs.

You can download Liberica from either the Liberica JDK Download Center or, as a support-plan customer, via a link on the support portal. After you log in to the support portal, you can see a direct link to the version of Liberica product you requested under Technologies. If you use the Liberica Download Center page, scroll down and select the OS, package type, and the distribution variant (JDK/JRE). After the download is completed, you can verify the downloaded file by comparing its size on your drive to the size on the Downloads page.

You can also use the command line to download the necessary installation packages as described further in this document.

Choose the OS below for specific installation instructions. Note that Liberica JDK is used for all examples below, but you can substitute it with Liberica JRE if necessary.

Microsoft Windows

Installing Liberica JDK using .msi file

  1. Double click the Windows installation file you downloaded to run the installer. This opens the Liberica JDK Setup Wizard.

  2. Click 'Next' on the Welcome screen.

  3. On the Custom Setup window, choose features you need. Select a feature to see its description. In most cases, you can use the default setup. Click Disk Usage to see the available and required space on your disk. Click 'Next'.

    Features

  4. The package is ready to install, press 'Install'. If you see the User Account Control warning, verify the publisher (BELLSOFT) and click Yes.

  5. After the installation is complete, click 'Finish' to quit the Liberica JDK Setup Wizard.

Note

The installer screens above may vary in different releases.

Silent installation using .msi file

If you want to install Liberica JDK silently without any user interaction, open the command line and run the following command:

msiexec /i bellsoft-jdk17.0.7+7-windows-amd64.msi /qn /quiet /norestart /l*v "Liberica_install.log"

Where

  • /i - install the specified software;
  • /qn - no UI;
  • /quiet - quiet mode without any user interaction;
  • /norestart - does not restart the computer after the installation is complete;
  • /l*v "Liberica_install.log" - verbose logging of all messages to the specified log file.

For the list of installation flags and options, run msiexec /help from the command line.

Note

Use administrator account to run the installation in silent mode.

Installing a standalone package from an archive

  1. To install Liberica JDK as a standalone package on your computer, download the .zip package file and unpack it to a folder. You can also use Windows PowerShell to download and unpack the zip file as follows:

    Invoke-WebRequest "https://download.bell-sw.com/java/17.0.7+7/bellsoft-jdk17.0.7+7-windows-amd64.zip"
    Expand-Archive bellsoft-jdk17.0.7+7-windows-amd64.zip -DestinationPath .

    The commands above download the archive from the BELLSOFT public domain and unpack Liberica JDK to the current directory. If you are a support-plan customer, log in to the support portal, copy the link to the Liberica product under Technologies and paste this link to the Invoke-WebRequest command above.

  2. Add <Liberica JDK installation dir>/bin subdirectory to the PATH and <Liberica JDK installation dir> to the JAVA_HOME environment variables as follows.

    1. On the desktop or in File Explorer, right-click the Computer icon (This PC) and choose Properties on the context menu.

    2. Click Advanced system settings.

    3. Click Environment Variables.

    4. Select 'Path' in System variables and click Edit.

    5. Click New and type the path to the /bin subdirectory, for example:

      C:/LibericaJDK8/bin/

      Click OK when finished.

    6. Select 'JAVA_HOME' in System variables and click Edit.

    7. Delete the variable's current value and type the path to the <Liberica JDK installation dir> subdirectory.

      Note

      If you do not have the JAVA_HOME variable, click New under System variables and type JAVA_HOME in Variable name and type the path in Variable value.

    8. Click OK in open dialog boxes to save the changes and reopen Command prompt window for the changes to take effect.

To run your application, use the following command:

java -jar <your_application.jar>

Verifying your installation

To verify your installation, open a command-line interface, such as PowerShell or cmd, and run the following command:

java -version

You should see an output similar to the following:

openjdk version "17.0.7" 2023-01-17 LTS
OpenJDK Runtime Environment (build 17.0.7+7-LTS)
OpenJDK 64-Bit Server VM (build 17.0.7+7-LTS, mixed mode, sharing)

Uninstalling Liberica JDK

Windows installer

If you installed Liberica JDK using Windows installation file (.msi), use the following procedure:

  1. From the Windows Control Panel, open Programs > Programs and Features and select Liberica package you want to remove.

  2. Click Uninstall.

Standalone package

To uninstall a standalone Liberica JDK package, remove its directory and related environmental variables in the Environment Variables dialog box.

Apple macOS

Installing Liberica JDK

To install Liberica JDK, perform the following:

  1. Run the installer by double-clicking the .dmg file you downloaded.

  2. Double-click the Install Liberica JDK pkg icon to run the installation wizard.

    Liberica JDK installation package

  3. Click Continue on the Welcome screen.

  4. Click 'Install' to proceed with the default location.

    Installation Type screen

    Optionally, you can change the install location by clicking 'Change Install Location' on the Installation Type screen and selecting the location to install Liberica JDK.

    Choose Install Location screen

    If you chose to change the install location, select the destination drive and click 'Continue'.

  5. Confirm new software installation. The file copying starts immediately.

    Security Warning screen

  6. Observe the installation progress.

  7. Once the installation is complete, click 'Close' to quit the installation wizard.

Installing a standalone package from an archive

To install Liberica JDK as a standalone package, download the .zip file and unpack it as in the following example.

wget https://download.bell-sw.com/java/17.0.7+7/bellsoft-jdk17.0.7+7-macos-amd64.zip
unzip bellsoft-jdk17.0.7+7-macos-amd64.zip

The commands above download the archive from the BELLSOFT public domain and unpack Liberica JDK to the current directory. If you are a support-plan customer, log in to the support portal, copy the link to the Liberica product under Technologies and paste this link to the wget command above.

Include the path to the <Liberica installation dir>/bin subdirectory when running your Java application as in the following example:

/Library/Java/JavaVirtualMachines/liberica-jdk-17.0.7/bin/java -jar $your_app

You can add the <Liberica installation dir>/bin subdirectory to the $PATH and <Liberica installation dir> to the JAVA_HOME environment variables for the current terminal session if necessary

export PATH=<Liberica installation dir>/bin:$PATH
export JAVA_HOME=<Liberica installation dir>

and run Liberica JDK as follows.

java -jar $your_app

Verifying your installation

To verify your installation, open the terminal and run the following command:

java -version

You should see an output similar to the following:

openjdk version "17.0.7" 2023-04-19 LTS
OpenJDK Runtime Environment (build 17.0.7+7-LTS)
OpenJDK 64-Bit Server VM (build 17.0.7+7-LTS, mixed mode, sharing)

Uninstalling Liberica JDK

Package installer

To uninstall Liberica JDK using the package installer, perform the following:

  1. Run the installer by double-clicking the .dmg file you downloaded.

  2. Double-click the Uninstall Liberica.app icon.

    DMG content

  3. Click 'Continue' on the Welcome screen.

    Liberica uninstaller

  4. Select the Liberica installation you want to remove and click Continue.

  5. Provide authentication information if necessary and click OK. Once the uninstallation is completed, click Exit to quit the wizard.

Command line

To uninstall Liberica application using the Terminal, do the following (assuming that you installed Liberica using the default location on the boot volume (/)).

  • To uninstall Liberica JRE, run the following commands in the terminal:

    sudo pkgutil --volume / --forget com.bell-sw.liberica.jre.17.0.7
    sudo rm -rf /Library/Java/JavaVirtualMachines/liberica-jre-17.0.7
  • To uninstall Liberica JDK, run the following commands in the terminal:

    sudo pkgutil --volume / --forget com.bell-sw.liberica.jdk.17.0.7
    sudo rm -rf /Library/Java/JavaVirtualMachines/liberica-jdk-17.0.7

Note

For Liberica JDK lite or full versions add -lite or -full respectively to the name, such as liberica-jdk-17.0.7-full.

Standalone package

To uninstall a standalone Liberica JDK package, remove its directory. Related environment variables set with the export command are only valid for the current terminal session and they are removed once you close the terminal.

Linux

On most Linux versions, you can install new software using a repository, which is a storage location hosted on remote servers from which the system retrieves and installs software and updates. If the repository is not available or due to some other considerations, you can download and install new software manually.

Installing from repository

Alpine Linux Repository

To install Liberica JDK, perform the following.

  1. Setup the repository.

    echo "https://apk.bell-sw.com/main" | sudo tee -a /etc/apk/repositories
    sudo wget -P /etc/apk/keys/ https://apk.bell-sw.com/[email protected]

    Note

    sudo command may require entering administrator password.

  2. Install packages.

    apk add bellsoft-java17

The following packages are available:

  • bellsoft-java17 contains the optimal build for most desktops/servers;
  • bellsoft-java17-lite includes Liberica JDK with compressed modules and Server VM, without any extra packages;
  • bellsoft-java17-runtime includes Liberica JRE only.

APT Repository (.deb-based Linux distributions)

To install Liberica JDK, perform the following.

  1. Add BELLSOFT official GPG key and set up the repository. Adding the GPG key is required only once on a computer.

    wget -q -O - https://download.bell-sw.com/pki/GPG-KEY-bellsoft | sudo apt-key add -
    echo "deb https://apt.bell-sw.com/ stable main" | sudo tee
    /etc/apt/sources.list.d/bellsoft.list

    Liberica JDK repositories contain all Linux architectures supported in the release: amd64, i386, arm64, armhf, ppc64le.

  2. Update repositories and install packages. Type Y if a warning message about the installed packages appears.

    sudo apt-get update
    sudo apt-get install bellsoft-java17

The following packages are available:

  • bellsoft-java17 contains the full Liberica JDK, including JavaFX and a variety of JVMs for platforms which support it;
  • bellsoft-java17-lite includes Liberica JDK with compressed modules and Server VM, without any extra packages;
  • bellsoft-java17-full contains the full Liberica JDK, including JavaFX and a variety of JVMs for platforms which support it;
  • bellsoft-java17-runtime includes Liberica JRE with JavaFX.

YUM Repository (.rpm-based Linux Distributions)

To install Liberica JDK, perform the following.

  1. Set up the repository.

    echo | sudo tee /etc/yum.repos.d/bellsoft.repo > /dev/null << EOF
    [BELLSOFT]
    name=BELLSOFT Repository
    baseurl=https://yum.bell-sw.com
    enabled=1
    gpgcheck=1
    gpgkey=https://download.bell-sw.com/pki/GPG-KEY-bellsoft
    priority=1
    EOF

    Liberica JDK repositories contain all Linux architectures supported in the release.

  2. Update repositories and install packages.

    sudo yum update
    sudo yum install bellsoft-java17

The following packages are available:

  • bellsoft-java17 contains contains the the optimal build for most desktops/servers;
  • bellsoft-java17-lite includes Liberica JDK with compressed modules and Server VM, without any extra packages;
  • bellsoft-java17-full contains the full Liberica JDK, including JavaFX and a variety of JVMs for platforms which support it;
  • bellsoft-java17-runtime includes Liberica JRE only.

YaST/Zypper Repository (SUSE Linux)

To install Liberica JDK, perform the following.

  1. Set up the repository.

    echo | sudo tee /etc/zypp/repos.d/repo-bellsoft.repo > /dev/null << EOF
    [BELLSOFT]
    name=BELLSOFT Repository
    baseurl=https://yum.bell-sw.com
    enabled=1
    gpgcheck=1
    gpgkey=https://download.bell-sw.com/pki/GPG-KEY-bellsoft
    priority=1
    EOF
  2. Update repositories and install packages.

    sudo zypper up
    sudo zypper in bellsoft-java17

The following packages are available:

  • bellsoft-java17 contains the the optimal build for most desktops/servers;
  • bellsoft-java17-lite includes Liberica JDK with compressed modules and Server VM, without any extra packages;
  • bellsoft-java17-full contains the full Liberica JDK, including JavaFX and a variety of JVMs for platforms which support it;
  • bellsoft-java17-runtime includes Liberica JRE only.

Manual installation

Alpine Linux

  1. Download the following package using the 'wget' command in the terminal.

    wget https://download.bell-sw.com/java/17.0.7+7/bellsoft-jdk17.0.7+7-linux-x64-musl.apk

    Or open the downloads page in the browser, scroll down, and download the required package.

  2. Install this package with the following command.

    apk add --allow-untrusted bellsoft-jdk17.0.7+7-linux-x64-musl.apk

Ubuntu and other DEB-based OS's

  1. To install Liberica JDK, download the .deb package using the 'wget' command in the command-line interface.

    wget https://download.bell-sw.com/java/17.0.7+7/bellsoft-jdk17.0.7+7-linux-amd64.deb

    Or open the downloads page in the browser, scroll down, and download the required package.

  2. Run the 'apt' tool as follows.

    sudo apt install ./bellsoft-jdk17.0.7+7-linux-amd64.deb

To use Liberica JDK, run the following command.

   java -jar $your_app

Red Hat Linux and other RPM-based OS's

To install Liberica JDK, download the .rpm package and run the rpm tool as in the following example.

wget https://download.bell-sw.com/java/17.0.7+7/bellsoft-jdk17.0.7+7-linux-amd64.rpm
sudo yum install ./bellsoft-jdk17.0.7+7-linux-amd64.rpm

The commands above install Liberica JDK 17 package.

To use Liberica JDK, run the following command.

java -jar $your_app

Manual RPM installation

  1. Obtain BELLSOFT official GPG key and then import it as in the following example. Adding the GPG key is required only once on a computer.

    wget -q -O - https://download.bell-sw.com/pki/GPG-KEY-bellsoft
    sudo rpm --import GPG-KEY-bellsoft
  2. Download a package using the 'wget' command and install it as follows in the terminal.

    wget https://download.bell-sw.com/java/17.0.7+7/bellsoft-jdk17.0.7+7-linux-amd64.rpm
    sudo rpm --install bellsoft-jdk17.0.7+7-linux-amd64.rpm

Installing standalone JDK package on GNU/Linux from an archive

To install Liberica JDK, download the .tar.gz package and unpack it as follows.

wget https://download.bell-sw.com/java/17.0.7+7/bellsoft-jdk17.0.7+7-linux-amd64.tar.gz
tar -zxvf bellsoft-jdk17.0.7+7-linux-amd64.tar.gz

The commands above unpack Liberica JDK to the current directory. To run your Java application, use the following command:

<Liberica installation dir>/bin/java -jar $your_app

You can add the <Liberica installation dir>/bin subdirectory to $PATH and <Liberica installation dir> to JAVA_HOME for the current terminal session if necessary.

export PATH=<Liberica installation dir>/bin:$PATH
export JAVA_HOME=<Liberica installation dir>

After that run your Java application as follows.

java -jar $your_app

Verifying your installation

To verify your installation, open a command-line interface and run the following command.

java -version

You should see an output similar to the following:

openjdk version "17.0.7" 2023-01-17 LTS
OpenJDK Runtime Environment (build 17.0.7+7-LTS)
OpenJDK 64-Bit Server VM (build 17.0.7+7-LTS, mixed mode, sharing)

Uninstalling Liberica JDK

Alpine Linux

Run the following command.

sudo apk del <bellsoft-package-name>

Ubuntu and other DEB-based OS's

Run the following command.

sudo apt remove <bellsoft-package-name>

Red Hat Linux and other RPM-based OS's

Run the following command.

sudo yum remove <bellsoft-package-name>

Removing manually installed standalone packages

To uninstall a standalone Liberica JDK package, remove its directory. Related environment variables are only valid for the current terminal session and they are removed once you close the terminal.

Verifying downloaded files

It is a good practice to verify the downloaded installation file by comparing its size on your drive to the size on the Downloads page.

A more advanced approach is to obtain the checksum of the downloaded file in a command-line interface and compare it to the one you can find next to the Liberica JDK link on the Downloads page. Check the OS-specific commands below.

Windows

To get the checksum of the downloaded file in the command-line, run the following command in Windows PowerShell. To run PowerShell, open the Start menu or press the Windows key + R, type powershell in the Run dialog box, and click OK.

(Get-FileHash .\bellsoft-jdk17.0.7+7-windows-amd64.msi -Algorithm SHA1).Hash

Apple macOS

To get the checksum of the downloaded file, use the following command.

shasum -a 1 bellsoft-jdk17.0.7+7-macos-amd64.dmg

Linux

To get the checksum of the downloaded file, use the following command. The installation file extension depends on the Linux version.

shasum -a 1 bellsoft-jdk17.0.7+7-linux-amd64.apk

Troubleshooting

This segment provides instructions to resolve some of the most common installation issues.

Checking system requirements

The JDK code can run on a number of platforms, using different compilers and build tools. We recommend checking your system compatibility and requirements on the Supported System Configurations page before installing Liberica product.

Microsoft Defender SmartScreen warnings

To ensure the security of the user's computer, Microsoft Defender SmartScreen sometimes prevents running the downloaded files and triggers warnings while installing software.

If Microsoft Defender SmartScreen prevents installing the Liberica product and shows a message similar to the one below, follow the instructions in this section.

Microsoft Defender SmartScreen warning

  1. Verify the downloaded Liberica installation file as described in Verifying downloaded files.

  2. Ensure that the installation file is signed by BELLSOFT by checking the details of the Digital Signatures in the Liberica installation file Properties.

    Liberica installation file properties

  3. Depending on the verification results, do the following:

    • If the size and checksum of the downloaded file matches those on the Downloads page and the file is signed by BELLSOFT, click More info on the Microsoft Defender SmartScreen window and then click Run anyway.
    • If any of the verified information is not correct, delete the file and download the Liberica installation file again.

Downloading Liberica using Edge

If the Edge browser prevents saving the downloaded Liberica installation file, click More actions next to the downloaded file and select Keep to save the file.

Edge browser download warning.

Silent installation on Windows

If after running a silent installation the software is not installed, check your log file for error messages. If the issue is the lack of administrator rights of the account running the installation, the log should contain a message similar to the following:

Error 1925. You do not have sufficient privileges to complete this installation for all users of the machine. Log on as administrator and then retry this installation.

Make sure you use administrator account for running silent installation.

Reverting to a previous Liberica product version on Windows

Important

We do not recommend installing previous versions of Liberica products, because they may contain security issues resolved in the latest release.

If you have the latest version of a Liberica product installed and need to install some previous version of exactly the same product, first uninstall the current version and after that, install the version you need.

Off-screen rendering

Containerized deployments sometimes do some off-screen rendering, such as when preparing documents, forms, and images. When performing off-screen rendering, the JDK requires OS fonts and fontconfig libraries to be installed. In case these libraries or fonts are absent, you can encounter an exception similar to the one below:

Caused by: java.lang.NullPointerException
	at java.desktop/sun.awt.FontConfiguration.getVersion(FontConfiguration.java:1264)
	at java.desktop/sun.awt.FontConfiguration.readFontConfigFile(FontConfiguration.java:225)
	at java.desktop/sun.awt.FontConfiguration.init(FontConfiguration.java:107)
	at java.desktop/sun.awt.X11FontManager.createFontConfiguration(X11FontManager.java:719)
	at java.desktop/sun.font.SunFontManager$2.run(SunFontManager.java:379)
	at java.base/java.security.AccessController.doPrivileged(Native Method)
	at java.desktop/sun.font.SunFontManager.<init>(SunFontManager.java:324)
	at java.desktop/sun.awt.FcFontManager.<init>(FcFontManager.java:35)
	at java.desktop/sun.awt.X11FontManager.<init>(X11FontManager.java:56)

On Linux systems, these libraries are provided by fontconfig and font packages, and can be installed by running the following command.

  • Alpine Linux: apk add fontconfig ttf-dejavu
  • Ubuntu: apt install fontconfig fonts-dejavu
  • Fedora: yum install fontconfig dejavu-sans-fonts dejavu-serif-fonts
  • Suse: zypper install fontconfig dejavu-fonts

To run off-screen rendering by JDK without installing the fontconfig package, do the following:

Install or copy required fonts to the system, manually edit fontconfig.properties file, and copy it to the <jdk>/lib directory. A simple fontconfig.properties file could look like the following.

Note

Update the paths and the font names to actual paths and names of the fonts on the target system.

version=1
 
 serif.plain.latin-1=DejaVu Serif
 serif.bold.latin-1=DejaVu Serif Bold
 serif.italic.latin-1=DejaVu Serif Italic
 serif.bolditalic.latin-1=DejaVu Serif Bold Italic
 
 sansserif.plain.latin-1=DejaVu Sans
 sansserif.bold.latin-1=DejaVu Sans Bold
 sansserif.italic.latin-1=DejaVu Sans Oblique
 sansserif.bolditalic.latin-1=DejaVu Sans Bold Oblique
 
 monospaced.plain.latin-1=DejaVu Sans Mono
 monospaced.bold.latin-1=DejaVu Sans Mono Bold
 monospaced.italic.latin-1=DejaVu Sans Mono Oblique
 monospaced.bolditalic.latin-1=DejaVu Sans Mono Bold Oblique
 
 dialog.plain.latin-1=DejaVu Sans
 dialog.bold.latin-1=DejaVu Sans Bold
 dialog.italic.latin-1=DejaVu Sans Oblique
 dialog.bolditalic.latin-1=DejaVu Sans Bold Oblique
 
 dialoginput.plain.latin-1=DejaVu Sans Mono
 dialoginput.bold.latin-1=DejaVu Sans Mono Bold
 dialoginput.italic.latin-1=DejaVu Sans Mono Oblique
 dialoginput.bolditalic.latin-1=DejaVu Sans Mono Bold Oblique
 
 sequence.allfonts=latin-1
 
 filename.DejaVu_Sans=/usr/share/fonts/truetype/DejaVuSans.ttf
 filename.DejaVu_Sans_Bold=/usr/share/fonts/truetype/DejaVuSans-Bold.ttf
 filename.DejaVu_Sans_Bold_Oblique=/usr/share/fonts/truetype/DejaVuSans-BoldOblique.ttf
 filename.DejaVu_Sans_Mono=/usr/share/fonts/truetype/DejaVuSansMono.ttf
 filename.DejaVu_Sans_Mono_Bold=/usr/share/fonts/truetype/DejaVuSansMono-Bold.ttf
 filename.DejaVu_Sans_Mono_Bold_Oblique=/usr/share/fonts/truetype/DejaVuSansMono-BoldOblique.ttf
 filename.DejaVu_Sans_Mono_Oblique=/usr/share/fonts/truetype/DejaVuSansMono-Oblique.ttf
 filename.DejaVu_Sans_Oblique=/usr/share/fonts/truetype/DejaVuSans-Oblique.ttf
 filename.DejaVu_Serif=/usr/share/fonts/truetype/DejaVuSerif.ttf
 filename.DejaVu_Serif_Bold=/usr/share/fonts/truetype/DejaVuSerif-Bold.ttf
 filename.DejaVu_Serif_Bold_Italic=/usr/share/fonts/truetype/DejaVuSerif-BoldItalic.ttf
 filename.DejaVu_Serif_Italic=/usr/share/fonts/truetype/DejaVuSerif-Italic.ttf
ON THIS PAGE