[jdk25u-dev] RFR: 8374644: Regression in GZIPInputStream performance after JDK-7036144
Roland Mesde
duke at openjdk.org
Wed Jan 14 19:36:52 UTC 2026
On Fri, 9 Jan 2026 17:49:54 GMT, Roland Mesde <duke at openjdk.org> wrote:
> Backporting JDK-8374644: Regression in GZIPInputStream performance after JDK-7036144
>
> This PR fixes a performance regression in GZIPInputStream introduced in JDK 23 by JDK-7036144. The original change replaced InputStream.available() with explicit InputStream.read() calls to detect concatenated GZIP streams, but this caused EOFException construction in the common case of single GZIP streams.
>
> Since Throwable construction involves expensive stacktrace filling, this created a performance regression for the most common use case. The fix introduces an alternate code path in readHeader() that avoids EOFException generation when the stream has reached EOF, restoring performance to JDK 22 levels while maintaining the functional improvements from JDK-7036144.
>
> This backport has internal demand.
>
> Ran related tests on linux-x64, linux-aarch64, macos-aarch64 and windows-x64:
>
> make test TEST=test/jdk/java/util/zip/GZIP
>
> Results attached:
>
> [linux-x64-specific-test.log](https://github.com/user-attachments/files/24574341/linux-x64-specific-test.log)
> [linux-aarch64-specific-test.log](https://github.com/user-attachments/files/24574343/linux-aarch64-specific-test.log)
> [windows-x64-specific-test.log](https://github.com/user-attachments/files/24574344/windows-x64-specific-test.log)
> [macos-aarch64-specific-test.log](https://github.com/user-attachments/files/24574345/macos-aarch64-specific-test.log)
Hi Goetz,
This is the backport for 26: https://github.com/openjdk/jdk26u/pull/12
-------------
PR Comment: https://git.openjdk.org/jdk25u-dev/pull/139#issuecomment-3751260716
More information about the jdk-updates-dev
mailing list