Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

WebP: OOM for test file #730

Open
BigMichi1 opened this issue Jan 20, 2023 · 4 comments
Open

WebP: OOM for test file #730

BigMichi1 opened this issue Jan 20, 2023 · 4 comments

Comments

@BigMichi1
Copy link

BigMichi1 commented Jan 20, 2023

Describe the bug
we have a sample webp file which causes an OOM and we want to understand if this is something we need to expect (reading webp files need a lot of memory) or if there is something not correct in the image reader.

Version information

  1. The version of the TwelveMonkeys ImageIO library in use.
    3.9.4

  2. The exact output of java --version (or java -version for older Java releases).
    For example:

    openjdk version "17.0.5" 2022-10-18
    OpenJDK Runtime Environment Temurin-17.0.5+8 (build 17.0.5+8)
    OpenJDK 64-Bit Server VM Temurin-17.0.5+8 (build 17.0.5+8, mixed mode, sharing)
  1. Extra information about OS version, server version, standalone program or web application packaging, executable wrapper, etc. Please state exact version numbers where applicable.

To Reproduce
Steps to reproduce the behavior:

  1. Compile the below sample code
  2. Download the sample image file
  3. Run the code with the sample file and Xmx set to 1024m or lower
  4. See error

Expected behavior
should work with Xmx lower than 1280m

Example code

    @Test
    public void triggerOOM() throws IOException {
        try (final var file = new ClassPathResource("sample-webp-file-for-testing.webp").getInputStream()) {
            final var image = ImageIO.read(file);
            assertThat(image).isNotNull();
        }
    }

Less is more. Don't add your entire project, only the code required to reproduce the problem. 😀

Sample file(s)
sample-webp-file-for-testing.zip

Stak trace

  java.lang.OutOfMemoryError: Java heap space
    at com.twelvemonkeys.imageio.plugins.webp.vp8.MacroBlock.predictUV(MacroBlock.java:492)
    at com.twelvemonkeys.imageio.plugins.webp.vp8.MacroBlock.dequantMacroBlock(MacroBlock.java:211)
    at com.twelvemonkeys.imageio.plugins.webp.vp8.VP8Frame.decodeMacroBlockRow(VP8Frame.java:366)
    at com.twelvemonkeys.imageio.plugins.webp.vp8.VP8Frame.decode(VP8Frame.java:346)
    at com.twelvemonkeys.imageio.plugins.webp.WebPImageReader.readVP8(WebPImageReader.java:657)
    at com.twelvemonkeys.imageio.plugins.webp.WebPImageReader.readVP8Extended(WebPImageReader.java:484)
    at com.twelvemonkeys.imageio.plugins.webp.WebPImageReader.readVP8Extended(WebPImageReader.java:463)
    at com.twelvemonkeys.imageio.plugins.webp.WebPImageReader.read(WebPImageReader.java:441)
    at java.desktop/javax.imageio.ImageIO.read(ImageIO.java:1470)
    at java.desktop/javax.imageio.ImageIO.read(ImageIO.java:1365)
@haraldk
Copy link
Owner

haraldk commented Jan 20, 2023

Thanks for reporting!

While your WebP file is rather large (8000 x 6000 x 3 ~= 140 MB in memory), I have to agree that the memory requirements for decoding seem a bit unreasonable...

I didn't write this code myself, so I don't know it with enough detail to say much about why the requirements are this high, or what can be done to optimize the memory usage. Any insights or suggestions at optimizations are very welcome!

@haraldk haraldk changed the title OOM for webp test file WebP: OOM for test file Mar 7, 2023
@mcpierce
Copy link

I'm having a similar issue with running things on a Raspberry Pi box. My project's unit tests fail, but they pass on other platforms (MacOS, Windows, Linux).

@xudl33
Copy link

xudl33 commented Nov 28, 2024

I‘m goted same issue with use mulity thread to read webp . I created 20 threads to read nomal webp (only hundreds Kb,not too large )but is cost alot of heapspace to let me goted a OOM Exception.

TwelveMonkeys version 3.8.3

image

@haraldk
Copy link
Owner

haraldk commented Dec 2, 2024

Unless more detail is provided, like the file you are trying to decode, and the code you use, unfortunately, this isn't something I can use to fix the issue.

Note that the file size is not what matters, it's the decoded file and how it is compressed. Using 20 threads will use 20x the memory, that's expected.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants