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

Mostly jp2 images are not opening it is working in cantaloupe.Attaching error screenshot #153

Open
ranjeetsinghthirdrock opened this issue Aug 7, 2024 · 17 comments · Fixed by #159

Comments

@ranjeetsinghthirdrock
Copy link

Screenshot from 2024-08-07 12-00-39

@mbklein
Copy link
Member

mbklein commented Aug 12, 2024

@orangewolf Is this something you've seen before?

@guillenjs
Copy link

I was wondering if this was resolved. I ran into the same problem when using jp2 images.

@mbklein
Copy link
Member

mbklein commented Oct 8, 2024

@ranjeetsinghthirdrock @guillenjs Do you have any jp2 source images you can share with me so that I can try to reproduce and fix this issue? You can either attach them here or email them to [my github username] at gmail.

@mbklein
Copy link
Member

mbklein commented Oct 15, 2024

@ranjeetsinghthirdrock After some debugging with a sample file provided by @guillenjs, I have narrowed the issue down to the JP2 loader in the underlying libvips image processing library. I have submitted a bug report in hopes of getting things working. If either of you would be willing to let me attach any of the files that are giving you trouble to that issue (or even attach them yourselves in comments), it would go a long way to helping resolve the issue.

@ranjeetsinghthirdrock
Copy link
Author

@mbklein
Copy link
Member

mbklein commented Oct 16, 2024

@ranjeetsinghthirdrock Would it be possible to share the source JP2 file for that image? Either by zipping/attaching it here, or by emailing it to mbklein at gmail?

@mbklein
Copy link
Member

mbklein commented Oct 29, 2024

@ranjeetsinghthirdrock @guillenjs The underlying issue is with the OpenJPEG library that provides JPEG 2000 support. It looks like there's going to be a libvips release with a workaround – not an ideal one, as it depends on loading the entire frame instead of just the tiles required to complete the request, but I've tested it on my development server and the lag isn't terrible. But it's the best option available until the upstream issue is addressed.

I've also reached out to the team at Kakadu to ask how their licensing might work given the way our distribution works. It would require downstream users (i.e., you) to obtain a valid license for the Kakadu libraries, but if you've had this working in Cantaloupe, it's possible you've already been using the KakaduNativeProcessor with a license? (If you've been using the Cantaloupe OpenJpegProcessor, you may not even notice the performance hit from the libvips workaround mentioned above.)

@guillenjs
Copy link

@mbklein Thank you for all the work on this front! Is there a projected date when this update may be released so we can start testing on our end?

@mbklein
Copy link
Member

mbklein commented Oct 30, 2024

I'm currently testing with the libvips branch with the fix in it. Once it's stable, the maintainer will have to approve, merge, and release it, and then I can build and push a Lambda layer with support for it. I hope it'll be soon – closer to "a couple weeks" than "a few weeks."

@mbklein
Copy link
Member

mbklein commented Nov 1, 2024

I'm afraid I didn't quite understand the libvips release schedule, so it might be six months or so before the fix is in a release. That said, there's nothing stopping me from building a lambda layer with the pre-release workaround in it, so I'll let you know when it's available.

@mbklein
Copy link
Member

mbklein commented Nov 9, 2024

@ranjeetsinghthirdrock @guillenjs I've just released serverless-iiif v5.1.1 with support for the sharp/libvips/openjpeg workaround for this issue. It uses as-yet unreleased code from libvips and a forked version of sharp that enables the workaround code. I'll update to the released versions as the code make it into upstream releases.

If you have a chance, could you install or upgrade to that version and see if it fixes the problems you're having?

@guillenjs
Copy link

@mbklein, thank you for the update. I will test this out this week and get back to you about it.

@guillenjs
Copy link

@mbklein I have been testing the new v5.1.1 release, and generally, everything seems to be working fine. I did try and find a large file that is 20,000+ pixels and 18.6MB. That is the one file that I seem to be struggling to work correctly. It is not the same issue as before. If I request a smaller size, I get the image returned, but when I request a full-size image, I get an "Internal server error."

So, I am wondering if there is a max pixel width/height that would be ideal to stay under.

Thanks again for the all the help!

@mbklein
Copy link
Member

mbklein commented Nov 20, 2024

It's less about pixel width and more about memory – if you look at the CloudWatch logs for that request you'll probably see something like

REPORT RequestId: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx Billed Duration: 3000 ms   Memory Size: 3008 MB   Max Memory Used: 3009 MB
RequestId: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx Process exited before completing request

If you deployed it using the default parameters, you could try bumping up the IiifLambdaMemory setting. It can go as high as 10240. But since the workaround for the issue we've been focused on involves loading the entire image into memory in one shot (instead of one tile at a time), it's also very likely that very large JPEG 2000 images with the multipart tile layout will eat way more memory than they would otherwise.

@boxerab
Copy link

boxerab commented Nov 27, 2024

Hello, I saw related issue opened on openjpeg tracker - there is an alternative to OpenJPEG and Kakadu that might help

/~https://github.com/GrokImageCompression/grok
https://www.bitsgalore.org/2022/03/30/generating-lossy-access-jp2s-from-lossless-preservation-masters

Grok (an older version) has been integrated into Cantaloupe but I'm not sure about adoption.

@mbklein
Copy link
Member

mbklein commented Dec 2, 2024

Thanks for pointing that out, @boxerab. I've passed that info along to the libvips maintainer; it'll be up to him to decide whether to add support for it.

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

Successfully merging a pull request may close this issue.

4 participants