java

JDK 8u381 Release Notes

Java SE 8u381 Bundled Patch Release (BPR) - Bug Fixes and Updates

The following sections summarize changes made in all Java SE 8u381 BPR. Bug fixes and any other changes are listed below in date order, most current BPR first. Note that bug fixes in the previous BPR are also included in the current BPR.

 

Changes in Java SE 8u381 b33

Bug Fixes

BugId Category Subcategory Summary
JDK-6176679 client-libs java.awt Application freezes when copying an animated gif image to the system clipboard
JDK-8286481 client-libs java.awt Exception printed to stdout on Windows when storing transparent image in clipboard
JDK-8314188 (not public) install install [macOS] Installation complete confirmation message not displayed

 

Changes in Java SE 8u381 b32

Bug Fixes

BugId Category Subcategory Summary
JDK-8306899 (not public) install install JRE 8u371 MSI unable to install side-by-side JREs
JDK-8311244 (not public) hotspot gc frequent crashes at g1CollectedHeap.cpp:5923 after updating to JDK8u371

 

Changes in Java SE 8u381 b31

Bug Fixes

BugId Category Subcategory Summary
JDK-8284542 jfx accessibility Missing attribute for toggle state of CheckBox in CheckBoxTreeItem
JDK-8309557 (not public) install Update the JRE 8 Description in RPM packages

Java™ SE Development Kit 8, Update 381 (JDK 8u381)

July 18, 2023

The full version string for this update release is 8u381-b09 (where "b" means "build"). The version number is 8u381.

 

IANA TZ Data 2023c

JDK 8u381 contains IANA time zone data 2023c which contains the following changes since the previous update.

  • Egypt now uses DST again, from April through October.
  • This year Morocco springs forward April 23, not April 30.
  • Palestine delays the start of DST this year.
  • Much of Greenland still uses DST from 2024 on.
  • America/Yellowknife now links to America/Edmonton.
  • tzselect can now use current time to help infer timezone.
  • The code now defaults to C99 or later.
  • Fix use of C23 attributes.
  • This release's code and data are identical to 2023a.

For more information, refer to Timezone Data Versions in the JRE Software.

 

Security Baselines

The security baselines for the Java Runtime Environment (JRE) at the time of the release of JDK 8u381 are specified in the following table:

JRE Family Version JRE Security Baseline (Full Version String)
88u381-b09

 

Keeping the JDK up to Date

Oracle recommends that the JDK is updated with each Critical Patch Update. In order to determine if a release is the latest, the Security Baseline page can be used to determine which is the latest version for each release family.

Critical patch updates, which contain security vulnerability fixes, are announced one year in advance on Critical Patch Updates, Security Alerts and Bulletins. It is not recommended that this JDK (version 8u381) be used after the next critical patch update scheduled for October 17, 2023.

Java SE Subscription customers managing JRE updates/installs for large number of desktops should consider using Java Advanced Management Console (AMC).

For systems unable to reach the Oracle Servers, a secondary mechanism expires this JRE (version 8u381) on 2023-11-17. After either condition is met (new release becoming available or expiration date reached), the JRE will provide additional warnings and reminders to users to update to the newer version. For more information, see 23.1.2 JRE Expiration Date in the Java Platform, Standard Edition Deployment Guide.

 

New Features

core-libs/java.lang
 Allow Additional Characters for GB18030-2022 Support (JDK-8301400)

The China National Standard body (CESI) has recently published GB18030-2022. This is an updated version of the GB18030 standard and brings GB18030 in sync with Unicode version 11.0. The purpose of this enhancement is to incorporate 35 code points (U+9FCD - U+9FEF) from Unicode 11.0 into Java SE 8 to allow implementations to comply with their Implementation Level 1 requirements.

core-libs/java.nio.charsets
 Support for GB18030-2022 (JDK-8307229)

The China National Standard body (CESI) has recently published GB18030-2022, which is an updated version of the GB18030 standard and brings GB18030 in sync with Unicode version 11.0. The Charset implementation for this new standard has now replaced the prior 2000 standard. However, this new standard has some incompatible changes from the prior implementation. For those who need to use the old mappings, a new system property, jdk.charset.GB18030, is introduced. By setting its value to 2000, the previous JDK releases' mappings for the GB18030 Charset are used, which are based on the 2000 standard.

core-libs/java.lang
 Allow Additional Characters for GB18030-2022 (Level 2) Support (JDK-8305681)

The China National Standard body (CESI) has recently published GB18030-2022. This is an updated version of the GB18030 standard and brings GB18030 in sync with Unicode version 11.0. The purpose of this enhancement is to incorporate 108 code points from CJK Unified Ideographs Extension E block from Unicode 11.0 into Java SE 8 to allow implementations to comply with their Implementation Level 2 requirements.

security-libs/javax.crypto
 JDK Now Accepts RSA Keys in PKCS#1 Format (JDK-8023980)

RSA private and public keys in PKCS#1 format can now be accepted by JDK providers, such as the RSA KeyFactory.impl from the SunRsaSign provider. The RSA private or public key object should have the PKCS#1 format and an encoding matching the ASN.1 syntax for a PKCS#1 RSA private key and public key.

 

Known Issues

install
 Problem Upgrading JDK on Windows if System User Is Using Shared Files (JDK-8310932 (not public))

Installing into the same, shared jdk-(family) directory is the default behavior for the JDK starting with the July 2023 CPU. It could lead to FilesInUse issues if JDK files are locked by the "System User". We recommend shutting down any apps using the JDK as the "System User" before upgrading.

hotspot/gc
 JVM Crashes with Internal Error (g1CollectedHeap.cpp:5923) after Upgrading to JDK 8u371 or JDK 8u381 (JDK-8311244 (not public))

There is the possibility of an application crash with the following error:

# Internal Error (g1CollectedHeap.cpp:5923), pid=xxxxx, tid=xxxxxx
# guarantee(!dcqs.completed_buffers_exist_dirty()) failed: must be

 

This affects JDK 8u371 and JDK 8u381 runtimes using G1 GC on all supported platforms.

The failure is now corrected in the JDK 8u381 b32 Bundle Patch Release available via My Oracle Support.

install
 No Default Java after 8u371 32-bit Upgrade (JDK-8306784 (not public))

Upgrading from an 8u361 (or earlier) 32-bit JRE to an 8u371 (or later) 32-bit JRE when an 8u371 (or later) 64-bit JRE is already installed will cause the java.exe command to not be found. For example:

  1. Install 32-bit 8u361
  2. Install 64-bit 8u371 (or later)
  3. Install 32-bit 8u371 (or later)

java.exe will now not work from all places. It will only work directly from the bin directory.

java.exe will not work unless you specify the full path to the bin directory of your JRE.

There are 2 workarounds:

  • Workaround 1: uninstall and reinstall the latest version of 64-bit 8u371 (or later)
  • Workaround 2: specify the full path to java.exe in the \bin directory of the JRE, for example: C:\Program Files\Java\jre-1.8\bin\java.exe

 

Other Notes

hotspot/runtime
 Cgroup v2 Support and Improvements in 8u381 (JDK-8307634)

JDK 8u381 includes several enhancements and fixes to improve the cgroup v1 and v2 support for containers. The improvements include accurately detecting the resource limits of containers, correctly reporting the collected container metrics, printing additional container information, and improving application stability in containerized environments.

Some of the notable stability enhancements are:

JDK-8292083: Java applications may experience out-of-memory errors and run the risk of being killed by the OOM killer when running in a containerized environment where the container is configured with a higher memory limit than the available physical memory on the host system. JDK 8u381 addresses this stability issue. In the previous release, this situation can be avoided by using either -XX:-UseContainerSupport, or -XX:MaxRAM=<physical memory>, or by setting a memory limit for your container that is lower than the physical memory.

JDK-8286030: This release addresses an issue where Java applications may encounter a fatal error when the same /tmp directory is shared across multiple containers. In earlier releases, this crash can be avoided by mounting /tmp to different locations for different containers. Alternatively, the '-XX:-UsePerfData' JVM option can be used to prevent JVMs running within different containers from writing performance data to the shared /tmp folder and thus avoid this issue.

install/install
 Starting in 8u371, the New RPM Package Obsoletes Older JDK 8 Packages and Disallows Downgrades (JDK-8307400)

Added an "Obsoletes" tag to JDK 8 RPM packages to allow automatic upgrades from older JDK 8 RPM packages.

  • jdk-1.8 package obsoletes jdk1.8 package.
  • jre-1.8 package obsoletes jre1.8 package.
  • jdk-1.8-headful package obsoletes jdk1.8 package.
  • jre-1.8-headful package obsoletes jre1.8 package.

No "Obsoletes" tag was added to the jdk-1.8-headless package to prevent upgrading from the full to headless JDK.

The changes allow automatic upgrades for JDK 8 RPM packages starting from the 8u151 update when jdk1.8 and jre1.8 package names were first introduced. Older JDK 8 updates will not be eligible for automatic upgrades to 8u381 and newer updates.

Due to the limitations of "Obsoletes" tag downgrades from 8u381 to older versions are not supported.

install/install
 Missing /usr/java/default Symlink on Linux Restored (JDK-8306690)

A regression where the /usr/java/default symlink is not created by RPM installers on Linux platforms has been fixed. Installers will create the /usr/java/default symlink if it doesn't exist, targeting the /usr/java/latest symlink.

install/install
 Installation of JDK RPM Corrupts Alternatives (JDK-8308244)

The JDK RPM installer will remove incorrectly constructed entries of "java" and "javac" groups registered by older Oracle JDK RPM installers from the alternatives before registering new "java" and "javac" entries.

An incorrectly constructed entry of the "java" group contains commands that are supposed to belong to the "javac" group.

An incorrectly constructed entry of the "javac" group contains commands that are supposed to belong to the "java" group.

All incorrectly constructed entries belonging to Oracle JDK RPM packages will be removed from the alternatives to avoid corruption of the alternatives internal data.

The removal has a potential side effect for users who have installed multiple JDK versions that are not updated to the latest release. Commands from a removed "java" or "javac" group are now unavailable for system Java switch, which potentially changes the current system Java without a warning. For example, if there is an out-of-date JDK RPM from an 11+ release, say 11.0.17, with an incorrectly constructed single "java" group installed and 8u381 RPM with this patch is installed, it will remove an entry from the "java" group belonging to the 11.0.17 RPM and thus will switch the current system Java from 11.0.17 to 8u381. The side effect will only happen when you install a lower JDK family with the fix, such as 8u381, and there is an out-of-date JDK from a higher family, such as 11.0.17, installed on the system. In that case, 8u381 will replace the older 11.0.17 as the latest. The remedy for the user is to install the latest JDK 11.

security-libs/java.security
 Added TWCA Root CA Certificate (JDK-8305975)

The following root certificate has been added to the cacerts truststore:

+ TWCA

  + twcaglobalrootca
    DN: CN=TWCA Global Root CA, OU=Root CA, O=TAIWAN-CA, C=TW

security-libs/java.security
 Added 4 GTS Root CA Certificates (JDK-8307134)

The following root certificates have been added to the cacerts truststore:

+ Google Trust Services LLC

 + gtsrootcar1
  DN: CN=GTS Root R1, O=Google Trust Services LLC, C=US

+ Google Trust Services LLC
 + gtsrootcar2
  DN: CN=GTS Root R2, O=Google Trust Services LLC, C=US

+ Google Trust Services LLC
 + gtsrootecccar3
  DN: CN=GTS Root R3, O=Google Trust Services LLC, C=US

+ Google Trust Services LLC
 + gtsrootecccar4
  DN: CN=GTS Root R4, O=Google Trust Services LLC, C=US

security-libs/java.security
 Added Microsoft Corporation's 2 TLS Root CA Certificates (JDK-8304760)

The following root certificates have been added to the cacerts truststore:

+ Microsoft Corporation

  + microsoftecc2017
    DN: CN=Microsoft ECC Root Certificate Authority 2017, O=Microsoft Corporation, C=US

+ Microsoft Corporation
  + microsoftrsa2017
    DN: CN=Microsoft RSA Root Certificate Authority 2017, O=Microsoft Corporation, C=US

core-libs/java.lang
 System Property java.specification.maintenance.version Set to 5 (JDK-8303028)

This JDK implements Maintenance Release 5 of the Java SE 8 specification (JSR 337). This is indicated by the system property java.specification.maintenance.version having the value of "5".

hotspot/runtime
 ASLR Support for CDS Archive (JDK-8294323 (not public))

Starting with the July 2023 CPU, on operating systems where ASLR (Address Space Layout Randomization) is enabled, the CDS archive will be placed at a random address picked by the operating system.

This change may have a minor performance impact: (a) Start-up time may increase because the JVM needs to patch pointers inside the CDS archive; (b) Memory usage may increase because the memory used by the CDS archive is no longer shareable across processes. We expect the impact to be small because such increases should be only a small fraction of the overall application usage.

In the unlikely event that you must disable ASLR for CDS, you can use the JVM flags -XX:+UnlockDiagnosticVMOptions -XX:ArchiveRelocationMode=0. The usage of such flags is not recommended.

security-libs/java.security
 Throw Error If Default java.security File Fails to Load (JDK-8155246)

A behavioral change has been made when the default conf/security/java.security security configuration file fails to load. In such a scenario, the JDK will now throw an InternalError.

Such a scenario should never occur. The default security file should always be present. Prior to this change, a static security configuration was loaded.

security-libs/java.security
 New System Property to Control the Maximum Size of Signature Files (JDK-8300596 (not public))

A new system property, jdk.jar.maxSignatureFileSize, has been added to allow applications to control the maximum size of signature files in a signed JAR. The value of the system property is the desired size in bytes. The default value is 8000000 bytes.

 

Bug Fixes

This release also contains fixes for security vulnerabilities described in the Oracle Critical Patch Update.

The following table lists the bug fixes included in the JDK 8u381 release:

# BugId Component Summary
1JDK-8304636client-libs/java.awtjava/awt/Mouse/EnterExitEvents/DragWindowTest.java fails with Compilation Error on JDK 8u
2JDK-8189604client-libs/java.awtpossible hang in sun.awt.shell.Win32ShellFolder2$KnownFolderDefinition::<clinit>
3JDK-8159956client-libs/java.awtEXCEPTION_ACCESS_VIOLATION in sun.awt.windows.ThemeReader.getThemeMargins
4JDK-8302151client-libs/javax.imageioBMPImageReader throws an exception reading BMP images
5JDK-8003399client-libs/javax.swingJFileChooser gives wrong path to selected file when saving to Libraries folder on Windows 7
6JDK-8017487client-libs/javax.swingfilechooser in Windows-Libraries folder: columns are mixed up
7JDK-8284756core-libs[11u] Remove unused isUseContainerSupport in CgroupV1Subsystem
8JDK-8212528core-libsWrong cgroup subsystem being used for some CPU Container Metrics
9JDK-8275735core-libs[linux] Remove deprecated Metrics api (kernel memory limit)
10JDK-8305681core-libs/java.langAllow additional characters for GB18030-2022 (Level 2) support
11JDK-8241786core-libs/java.netImprove heuristic to determine default network interface on macOS
12JDK-8211382core-libs/java.nio.charsetsISO2022JP and GB18030 NIO converter issues
13JDK-8301119core-libs/java.nio.charsetsSupport for GB18030-2022
14JDK-8172347core-libs/java.rmiRefactoring src/java.rmi/share/classes/sun/rmi/registry/RegistryImpl.java to improve testability of rmiregistry
15JDK-8212970core-libs/java.timeTZ database in "vanguard" format support
16JDK-8305400core-libs/java.util:i18nISO 4217 Amendment 175 Update
17JDK-8254001core-svc[Metrics] Enhance parsing of cgroup interface files for version detection
18JDK-8293540core-svc[Metrics] Incorrectly detected resource limits with additional cgroup fs mounts
19JDK-8292541core-svc/java.lang.management[Metrics] Reported memory limit may exceed physical machine memory
20JDK-8301282docs/guidesJMX simple and delegation security samples don't work because of missing access control entries
21JDK-8293821docs/guidesJDK LTS backports for Doc Tasks for JEP C206/C208: Modernize Oracle JDK Linux RPMs and installers on Windows and macOS
22JDK-8233023hotspot/compilerassert(Opcode() == mem->Opcode() || phase->C->get_alias_index(adr_type()) == Compile::AliasIdxRaw) failed: no mismatched stores, except on raw memory
23JDK-8210389hotspot/compilerC2: assert(n->outcnt() != 0 || C->top() == n || n->is_Proj()) failed: No dead instructions after post-alloc
24JDK-8217230hotspot/compilerassert(t == t_no_spec) failure in NodeHash::check_no_speculative_types()
25JDK-8062258hotspot/compilercompiler/debug/TraceIterativeGVN.java segfaults in trace_PhaseIterGVN
26JDK-8281297hotspot/gcTestStressG1Humongous fails with guarantee(is_range_uncommitted)
27JDK-8167196hotspot/gcWhiteBox methods should throw an exception if used with inappropriate collector.
28JDK-8264593hotspot/runtimedebug.cpp utilities should be available in product builds.
29JDK-8281274hotspot/runtimedeal with ActiveProcessorCount in os::Linux::print_container_info
30JDK-8266490hotspot/runtimeExtend the OSContainer API to support the pids controller of cgroups
31JDK-8273526hotspot/runtimeExtend the OSContainer API pids controller with pids.current
32JDK-8231610hotspot/runtimeRelocate the CDS archive if it cannot be mapped to the requested address
33JDK-8287741hotspot/runtimeFix of JDK-8287107 (unused cgv1 freezer controller) was incomplete
34JDK-8287107hotspot/runtimeCgroupSubsystemFactory.setCgroupV2Path asserts with freezer controller
35JDK-8286030hotspot/runtimeAvoid JVM crash when containers share the same /tmp dir
36JDK-8287011hotspot/runtimeImprove container information
37JDK-8293472hotspot/runtimeIncorrect container resource limit detection if manual cgroup fs mounts present
38JDK-8292083hotspot/runtimeDetected container memory limit may exceed physical machine memory
39JDK-8272124hotspot/runtimeCgroup v1 initialization causes NullPointerException when cgroup path contains colon
40JDK-8281517install/installImprove the error message shown when a user tries to install the aarch64 bundle on an intel mac
41JDK-8284662javafx/accessibility[Win][Accessibility][ListCell] Screen reader fails to read ListView/ComboBox item count if > 100
42JDK-8251862javafx/graphicsWrong position of Popup windows at the intersection of 2 screens
43JDK-8301009javafx/webUpdate libxml2 to 2.10.3
44JDK-8306115javafx/webUpdate libxml2 to 2.10.4
45JDK-8304441javafx/window-toolkit[macos] Crash when putting invalid unicode char on clipboard
46JDK-8296654javafx/window-toolkit[macos] Crash when launching JavaFX app with JDK that targets SDK 13
47JDK-8292297security-libs/java.securityFix up loading of override java.security properties file
48JDK-8173181security-libs/java.securityEmpty string alias in KeyStore throws StringIndexOutOfBoundsException for getEntry()
49JDK-8293858security-libs/java.securityChange PKCS7 code to use default SecureRandom impl instead of SHA1PRNG
50JDK-8294906security-libs/javax.crypto:pkcs11Memory leak in PKCS11 NSS TLS server
51JDK-8274205security-libs/org.ietf.jgss:krb5Handle KDC_ERR_SVC_UNAVAILABLE error code from KDC
52JDK-8301269xml/jaxpUpdate Commons BCEL to Version 6.7.0