Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/henrygd/optimize
Super fast cross-platform bulk image optimization with docker and libvips
https://github.com/henrygd/optimize
avif bun docker image-optimization image-processing libvips webp
Last synced: 3 months ago
JSON representation
Super fast cross-platform bulk image optimization with docker and libvips
- Host: GitHub
- URL: https://github.com/henrygd/optimize
- Owner: henrygd
- License: mit
- Created: 2024-02-13T16:44:53.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2024-06-18T10:35:10.000Z (7 months ago)
- Last Synced: 2024-06-18T23:28:46.933Z (7 months ago)
- Topics: avif, bun, docker, image-optimization, image-processing, libvips, webp
- Language: TypeScript
- Homepage:
- Size: 325 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
README
Dockerized script to bulk optimize images using [libvips](https://github.com/libvips/libvips) / [sharp](https://github.com/lovell/sharp) / [bun](https://bun.sh).
![example terminal command output: Total: 23.74MB saved from 8 images](assets/example.gif)
## Modes
`overwrite`: Overwrite existing images (default). Scans the directory mounted to `/images`.
```
docker run --rm -v ./images:/images -v ./backup:/backup henrygd/optimize
```---
`restore`: Restore original images from backup (reverses last `overwrite` operation).
```
docker run --rm -v ./images:/images -v ./backup:/backup -e MODE=restore henrygd/optimize
```---
`copy`: Write images to different directory. This example converts all images to WEBP.
```
docker run --rm -v ./images:/images -v ./optimized:/optimized -e MODE=copy -e FORMAT=webp henrygd/optimize
```## Environment Variables
| Name | Mode | Description | Default |
| ---------- | ---- | ----------------------------------- | ----------------------------------- |
| EXTENSIONS | \* | Extensions to optimize[^extensions] | jpg,jpeg,png,webp,tif,tiff |
| FIT | \* | [Fit method](#fit-methods) | inside |
| FORMAT | copy | Output format[^format] | unset |
| JOBS | \* | Number of parallel conversion jobs | Based on available CPU cores[^jobs] |
| MAX_AGE | \* | Age threshold in hours[^age] | unset |
| MAX_HEIGHT | \* | Max height of output image | 4000 |
| MAX_WIDTH | \* | Max width of output image | 4000 |
| MIN_SIZE | \* | Size threshold in kilobytes[^size] | unset |
| MODE | \* | [Mode](#modes) | overwrite |
| OWNER | \* | Ownership of new files[^owner] | root:root |
| QUALITY | \* | Output quality | 80 |
| QUIET | \* | Log only errors, not every file | unset |## Fit Methods
- `inside`: Preserving aspect ratio, resize the image to be as large as possible while ensuring its dimensions are less than or equal to both those specified.
- `cover`: Crop to cover both provided dimensions.
- `contain`: Embed within both provided dimensions.
- `fill`: Ignore the aspect ratio of the input and stretch to both provided dimensions.
- `outside`: Preserving aspect ratio, resize the image to be as small as possible while ensuring its dimensions are greater than or equal to both those specified.[^extensions]: Uppercase versions of extensions are added automatically.
[^size]: Images are only optimized if they are larger than `MIN_SIZE`. For example, `800` would only optimize images larger than 800kB.
[^age]: Images are only optimized if its file content was modififed in the last `MAX_AGE` hours. For example, `24` would only optimize images updated in the last 24 hours.
[^owner]: This applies only to newly created files. Overwritten files should maintain existing permissions. Value should use IDs. For example: `-e OWNER=1000:1000`, or `-e OWNER="$(id -u):$(id -g)"`.
[^format]: This will force all optimized images to be converted to the specified format. Possible values: `webp`, `avif`.
[^jobs]: Default `JOBS` value is one fewer than half of your available cores. If you have 16 cores, it's 7 jobs. If you have 4 cores or fewer, it's only one job.