Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vvzen/openimageio-dockerized
Proof of concept for dockerizing the build of OpenImageIO starting from the aswf docker images
https://github.com/vvzen/openimageio-dockerized
docker dockerfile openimageio
Last synced: 10 days ago
JSON representation
Proof of concept for dockerizing the build of OpenImageIO starting from the aswf docker images
- Host: GitHub
- URL: https://github.com/vvzen/openimageio-dockerized
- Owner: vvzen
- License: mit
- Created: 2023-10-03T06:52:02.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-10-30T10:37:32.000Z (about 1 year ago)
- Last Synced: 2024-12-23T23:32:37.990Z (17 days ago)
- Topics: docker, dockerfile, openimageio
- Language: Dockerfile
- Homepage:
- Size: 7.81 KB
- Stars: 0
- Watchers: 2
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# README
## What problem does this repo solve
Since OpenImageIO is written in C++, the task of compiling it correctly can prove to be very boring and error prone, so I have automated most of it through Docker.
### Requirements
If you're on linux, most things should work.
If you're on macOS, I'm working on a script.
If you're on Windows, I have no idea how to make it work.You will only need to have `docker` installed and its service active and running (on systemd distros, you can check via `sudo systemctl status docker`).
Before starting, download the tarballs containing all the dependencies needed to build OIIO:
``` shell
chmod +x ./download_tarballs.sh && ./download_tarballs.sh
```The Dockerfile will currently copy the `tarballs` directory into the image in an effort to keep the build process free from the need to access the internet (as much as it's possible).
If everything went fine, you should have this:
``` shell
$ tree tarballs
tarballs
├── boost_1_81_0.tar.bz2
├── LibRaw-0.21.1.tar.gz
├── OpenEXR_v2.4.15.0.tar.gz
├── OpenImageIO_v2.4.15.0.tar.gz
├── tiff-4.0.10.tar.gz
└── zlib-1.3.tar.gz
```### Running the build
To perform a build of OIIO, you can do something like this:
``` shell
# Run the dockerized build of OIIO (this might take a bit)
make docker-build# Copy the final tarball containing the final dist (libs+binaries)
make docker-export
```This will run the whole build process inside a Docker container and finally the copy the compiled bits back to your own filesystem.
All libraries and binaries are patched so that they are easily relocatable.The final result will be a `oiio-dist.tar.gz` tarballs whose content looks like this:
```bash
$ tar -xvf oiio-dist.tar.gz
$ tree dist -L 2
tree dist -L 2
dist
├── bin
│ ├── iconvert
│ ├── idiff
│ ├── igrep
│ ├── iinfo
│ ├── maketx
│ ├── oiiotool
│ └── testtex
├── include
│ └── OpenImageIO
├── lib64
│ ├── libboost_atomic.so.1.81.0
│ ├── libboost_chrono.so.1.81.0
│ ├── libboost_filesystem.so.1.81.0
│ ├── libboost_thread.so.1.81.0
│ ├── libjpeg.so.62
│ ├── libjpeg.so.62.3.0
│ ├── libOpenImageIO.so -> libOpenImageIO.so.2.4
│ ├── libOpenImageIO.so.2.4 -> libOpenImageIO.so.2.4.15
│ ├── libOpenImageIO.so.2.4.15
│ ├── libOpenImageIO_Util.so -> libOpenImageIO_Util.so.2.4
│ ├── libOpenImageIO_Util.so.2.4
│ ├── libOpenImageIO_Util.so.2.4.15
│ ├── libraw_r.so.23
│ ├── libtiff.so.5
│ ├── libturbojpeg.so.0
│ └── libturbojpeg.so.0.2.0
└── share
├── doc
└── fonts8 directories, 23 files
```Running through Docker also helps standardize the build steps so that the whole process is easily reproducible. The Dockerfile starts building using the `aswf/ci-base:2023.1` image as a base.
### How does this whole thing work?
This workflow uses a multi-stage `Dockerfile`.
There are 2 stages:
- build-stage (Build OIIO and its libraries)
- export-stage (Export the compiled bits back to your filesystem)These stages will:
- [build-stage] Compile all third-party libraries required by OpenImageIO
- This is done using the tarballs in the `tarballs` dir, so for most things no internet connection is required (the only things still cloned from a remote are Imath and libturbo-jpeg, and I'll fix it soon)
- [build-stage] Compile OpenImageIO and link against these third-party libraries
- [build-stage] Copy the required share libraries (.so files) needed to use OIIO at runtime
- [build-stage] Use `patchelf` to set the RPATH of all libraries to be relative
- This effectively makes them easy to relocate and move around
- [export-stage] Copy a tarball (`oiio-dist.tar.gz`) into your local filesystem
- This will contain the required headers and libs and binaries