Run Web Start based application after the release of Java 11

Java Web Start will die!

Java Web Start (JWS) was deprecated in Java 9 and starting with Java 11 Oracle will remove JWS from their JDK distributions. All this happened in September 2018. From this time on, it will be impossible to use JWS-based applications on clients, that have the latest version of Java installed. Since the public support of Java 8 ends in the 4 quarter of 2019 companies won’t get any updates and security fixes for Web Start anymore.

Based on this we at Karakun decided to create OpenWebStart as an open source reimplementation of the Web Start technology. The replacement should provide all general features of Web Start and will reuse the JNLP standard so that customers can continue to use applications based on Web Start and JNLP without any changes.


For more information about the removal of Java Web Start you can take a look at these documents:

Technical details

OpenWebStart will be based on the JNLP-specification defined in JSR-56 and will implement the most commonly used features of Java Web Start. It will be able to handle any typical JWS-based application and will support all future versions of Java starting from Java 11. Next to Java 11 we will support Java 8 directly with the first release of OpenWebStart. The following topics describe several aspects of the tool in more detail.

Installation and administration

OpenWebStart will come in 2 different version:

  • An installer with update functionality
  • An executable bundle

If you use Web Start for several small customers or on your own the installer will be perfect. By using a native installer (for Windows, Mac or Linux) OpenWebStart will be installed on your System and is directly ready to use. Next to this OpenWebStart will automatically check if an update is available. The tool contains an Updater component that will update OpenWebStart without any needed complete user interaction.

If you or your customers are companies with its own IT department the executable bundle can be used to rollout OpenWebStart on several client machines. In that case the update functionality of the tool is deactivated and the IT department can plan and handle the rollout of new versions based on internal workflows.


General modules and functionallities

The main focus of OpenWebStart is the execution of JNLP based applications. Next to this the tool contains 4 modules with additional functionality that helps to simplify the Web Start workflows and let you configure OpenWebStart just for your needs.

  • The App Manager will manage the versions of any JNLP based application that was executed by OpenWebStart
  • The JVM Manager will manage Java versions and its updates on the client
  • The Control Panel provides a graphical user interface to configure OpenWebStart
  • The Updater can automatically download and install new versions of OpenWebStart

JNLP support

OpenWebStart will provide exactly the same JNLP based workflow as Java Web Start, therefore nothing will change from the point of view of your users:

  • A JNLP-file that describes the application is downloaded to the client, typically either by clicking a link on a webpage or by an automated provisioning process.
  • OpenWebStart registers itself by default for the JNLP-file-extension and the MIME-type application/x-java-jnlp-file, therefore by double clicking the JNLP-file, OpenWebStart launches.
  • It parses the JNLP-file, downloads all needed resources (JARs, native libraries and images) and stores them in a cache.
  • Once all resources are available, the application starts.


Any JNLP based application that was downloaded and started via OpenWebStart will be managed by the internal App Manager. The App Manager will automatically check if an update is provided for any managed applications and downloads such update automatically.

JDK/JRE management

One feature that has always been missing with Oracle Web Start was JVM (Java Virtual Machine) version management. When deploying a JNLP based application a developer can not really define what exact Java version will be used to run the application. OpenWebStart from Karakun will add such functionality by the integrated JVM Manager. The JVM Manager can download Java versions from a dedicated server and manage such versions internally. By doing so a developer can easily define a specific Java version that should be used to run the provided JNLP based application.


By default OpenWebStart will download OpenJDK based Java version from a dedicated server. The server can be configured by hand in the Control Center of the Web Start tool.


Configuration of OpenWebStart

The well known Java Control Panel that was installed in addition to any Oracle Java installation was part of Web Start. Therefore it will be removed from Oracle Java along with Web Start. OpenWebStart provides its own Control Center. One feature of that Control Center will be the configuration of the workflow to start JNLP based applications by hand.

Customer specific build

If you want to evaluate the functionality of OpenWebStart without registering the tool for the JNLP MIME-type, we can provide a build that is configured to use a custom “JNLPX” MIME-type instead. Based on this, an easy migration from Oracle Web Start to the replacement will be possible. Next to this the server URL for JDK downloads can be configured. By doing so you can easily provide JDKs for your clients and customers on a custom server. If you want to use JDK with commercial support that should not be reachable in public OpenWebStart can be configured to download JDKs from a secure server by using authentication. All this configurations can be easily done for a customer that bought commercial support at Karakun. The free to use OpenWebStart builds are all configured in a default way.


A first base funding is secured and we start development mid of March. Beta tests will be available in Q2 2019. The following diagram shows the roadmap:



If you want to learn more or if you would like to discuss your specific needs, please contact us at or subscribe to our newsletter.