How to improve the performance of Rosetta thumbnail creation?
- Product: Rosetta
- Product Version: 7.x - 8.2
- Relevant for Installation Type: Local
Question
How to improve performance of Rosetta Thumbnail generation ?
Answer
- Verify that "Transformation Profile" Output Parameters option is selected for all "Thumbnail Task Rules" (under Rosetta Administration module).
"Stream Handler" Output Parameter option is available in Rosetta UI, however it is deprecated feature and not suggested to be used with Rosetta 4.0 or newer versions.
For more information please refer to: https://developers.exlibrisgroup.com/blog/creating-a-migration-tool-split-plug-in/ - Out-of-the-box "JPG Thumbnails" Transformation Profile can be used to generate a JPEG thumbnail from prevalent formats (image, video, PDF, etc),
it is configured to use "JPG-JPGMigrationTool" bundled Plugin, which uses ImageMagic utility (a 3rd party component deployed with Rosetta).To retrieve a list of file formats supported by ImageMagic, SSH to a Rosetta Application server as 'dps' Linux user and run: convert -list format
Additional file format notes and/or limitations are listed in ImageMagic official site.Below scripts is provided 'as is', it is EXPERIMENTAL and it may not work for all Rosetta environments, versions, scenarios, etc.
- SSH to any Application server as 'dps' Linux user and run:
cd $op_dir/plugins/bundled/bin/JPG-JPGMigrationTool-Vr-1.2/binwhich should deploy the optimized "$op_dir/plugins/bundled/bin/JPG-JPGMigrationTool-Vr-1.2/bin/run_jpg_deriv_copy.sh" script with MD5 checksum: 3b89d06e84c604abc60764b116e72cd9
cp -p run_jpg_deriv_copy.sh run_jpg_deriv_copy.sh.orig.SP`grep -iPo 'app.version=\K.*' $dps_system/conf/global.properties`-`date +'%Y%m%d'`
echo 'H4sICDuedmcCA3J1bl9qcGdfZGVyaXZfY29weS5zaAC9VdFu2zYUfddX3NBCbKGVZRt9SmJn2ZpmGVrUSFxgg+MFtETLXChSIyknWWtgH9Ev2KftS3ZJW1aCIkWHDREggCJ5D++55+iytZfMuUzm1CyD1jM9eBD8qG7BKkiVXPC80gwulGHW0raBiabSLJQuqOVKwlirBRcMjl3Y33/+BRMftmLaAgXDZY6LJc1ZYqp5zAscgVpAUQnLYz+/GWpmlKg8pFGVThk42JeAx+JIGwtjqmnBLNMGbrldgl1ugR+EyqqYMw0dLi3LmY66Liv/sG5+sKXkc1NS3Dd5fQkxcCcfQDyoeZ3Ie1hUGk/VGLdNBbgBKuHc0XpHc54iflFQmcWCS9bsMy9dAl2IDf+DwSeIf684EvsEzKbdbvdZtb2s8pwZy7InpESNSVNrcuAL8PnzpoyTJZZHUi4M1qZf84hTJZQ2JUXZLs6+B1dPR7Tf693hWyO8Zpqv8KwVgx9UeX/g4ooS9xr4aXx65tCo4PYe474G6TF7z1ezoAV8sTUhl2Vlna6Fk37rlXgEmQKpcEGr1NHhbidIdmdBKFW6yg1G+31IMrZKZCXEYYCQUwg7LF0qIOHH/pqgHXLNSoj5OIX2r/HxVfYibEcQ5xZ6MDt0jpcBAB8OAiYM88N+sOCY4K2mJVAhYI7puT9DUGMf+lTCXNP0hlkToOLQ6WBsyA9DfhS2Dt3wRR+iCHkg6uT65OJsSK4wrT2+viKknrscdnBuM5x+N8OU6881iXDT25PLbayPJEGmJPum+qVLKrEzEL9+7WwoMXPi/lhy5CfjenI0PdrGqRrV4Y1m5D/UdMPp2hEYNhTjPnLcrU7Dj62GO64N8agVFeDPa1+R9qPAadjpYA5JEuPeKJq5DZFTK3j/YTL+MLl+fX6xK1Rxk3EsROnSbpYx/8GoMU0d+Ob87enw8caEhB28JXyBHEatBOpCur+VOXEq0CxrvEF1XhVM2qBR+wG8E/0bJA8a/qTurN502B4eRW02JuxO8LnmJslKfF9d9xP8Y7IqtYlQKRUJL/x9V7hWerPr1Q+Rgne/nP58PhmGx4FrK183FjbiHcgCmxb2vI6x1FYG9oa9yIvvb5gvPdabER+uK9ncZznl0pvsX7lsfx8ZbNJeQ4zXAhqvcd4GZrxpHHhd7iyNV9PmuuQSuzXNnN0bS0XRk8YcPG1Mb/B1G9l5M+Lp/5csAI0w6HF2x23DOgj+ASEr+rPJCAAA' | base64 -d -i - | gzip -d - > run_jpg_deriv_copy.sh
dos2unix run_jpg_deriv_copy.sh
chmod +x run_jpg_deriv_copy.sh
- Update the relevant Transformation Profile (e.g. "JPG Thumbnails"), add a numerical switch (i.e. the File's inner page number) at the start of the "Parameters" field's value.
For example:
Assuming the current Transformation Profile "Parameters" field is defined with: -quiet -colorspace RGB -resize 100x100
Assuming we want to create a thumbnail from the 1st page/image/frame of a File, we should change it to: -1 -quiet -colorspace RGB -resize 100x100The above suggested optimized script should allow existing Transformation Profiles to work as they did before.
Adding additional numerical switch to the beginning of the "Parameters" field's value is only required to enable the above mentioned optimization. - [Optional] To test the above suggested optimized thumbnail creation script, we should clean the relevant thumbnail cache of the relevant IE/s for the Files we're testing (otherwise Rosetta would continue to retrieve it from cache, i.e. it will not recreate it using the optimized script).
To workaround that, run either "Clean Operational Thumbnails" or "Create Operational Thumbnails" (with "Replace existing thumbnail" option set to "yes") out-of-the-box Task-Chains on the relevant IE/s, then Deliver the thumbnail for the relevant File/s.
- SSH to any Application server as 'dps' Linux user and run:
- Further optimizations may be reached by further tweaking the Transformation Profile "Parameters" field (i.e. command-line options) that the relevant 3rd party utilities is using.
For example, in case of out-of-the-box "JPG-JPGMigrationTool" Plugin, "ImageMagic"* 3rd party utility is used.
* Please refer to ImageMagic official website for more information on ImageMagic command-line options:
https://imagemagick.org/script/command-line-options.php
- Out-of-the-box "JP2 Thumbnails" Transformation Profile can be used to generate a JPEG thumbnail from a JPEG2000 file format, it is configured to use "JP2-JPGMigrationTool" bundled Plugin, which uses both OpenJPEG and ImageMagic utilities (a 3rd party components deployed with Rosetta).
"JP2-JPGMigrationTool" Plugin version 1.3 "run_j2kdriver_thmb.sh" script's efficiency can be optimized (by using "reduce factor" option of OpenJPEG) to allow faster creation of intermediate PNG file that the plugin creates before it converts the latter to the final JPEG thumbnail.Below scripts is provided 'as is', it is EXPERIMENTAL and it may not work for all Rosetta environments, versions, scenarios, etc.
- SSH to any Application server as 'dps' Linux user and run:
cd $op_dir/plugins/bundled/bin/JP2-JPGMigrationTool-Vr-1.3/binwhich should deploy the optimized "$op_dir/plugins/bundled/bin/JP2-JPGMigrationTool-Vr-1.3/bin/run_j2kdriver_thmb.sh" script with MD5 checksum: 7817b04447b4b09a465135b7944ca565
cp -p run_j2kdriver_thmb.sh run_j2kdriver_thmb.sh.orig.SP`grep -iPo 'app.version=\K.*' $dps_system/conf/global.properties`-`date +'%Y%m%d'`
echo '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' | base64 -d -i - | gzip -d - > run_j2kdriver_thmb.sh
dos2unix run_j2kdriver_thmb.sh
chmod +x run_j2kdriver_thmb.sh - Update the relevant Transformation Profile (e.g. "JP2 Thumbnails"):
Suggested "Parameters": -thumb -quiet -colorspace RGB -resize 100x100- To resize output, pass: -<resize|thumbnail|scale|adaptive-resize|sample|resample> <x_resolution>x<y_resolution>
e.g.: -resize 150x150 - To create thumbnail, pass (only as first parameter): -t / -tmb / -thumb / -thumbnail
e.g.: -thumb
Note: "-resize 100x100" is passed by default in case none of above mentioned 'resize' parameters aren't passed.
Also, OpenJPEG "reduce factor" is used, its highest possible value is calculated by the script to produce intermediate image that should be larger (pixel wise) than the final ImageMagic resized image.
This is done to considerably reduce overall time it takes to create a thumbnail. - To control OpenJPEG "reduce factor" value, pass (only as first parameter): -<number>
e.g.: -2
Note: Default value is 0, i.e. nothing is discarded, which typically causes intermediate image output creation to take a long time. - To control OpenJPEG intermidiate output image format, pass (as first parameter): -<tif|TIF>
e.g.: -tif
Note: Default format is PNG, its size on storage is much smaller than TIF format output, but it's slower to create.
Using TIF format can speed up creation of Derivative Copy Files, assuming enough available storage space (for Thumbnail creation - the affect on the output generation speed is minor, but the storage footprint is notable).
- To resize output, pass: -<resize|thumbnail|scale|adaptive-resize|sample|resample> <x_resolution>x<y_resolution>
- [Optional] To test the above suggested optimized thumbnail creation script, we should clean the relevant thumbnail cache of the relevant IE/s for the Files we're testing (otherwise Rosetta would continue to retrieve it from cache, i.e. it will not recreate it using the optimized script).
To workaround that, run either "Clean Operational Thumbnails" or "Create Operational Thumbnails" (with "Replace existing thumbnail" option set to "yes") out-of-the-box Task-Chains on the relevant IE/s, then Deliver the thumbnail for the relevant File/s.
- SSH to any Application server as 'dps' Linux user and run:
- Article last edited: 02-Jan-2025