HINT: The docker images are no longer published on docker hub - only to ghrc.io!
This image is the unison-image for docker-sync and published ghcr.io eugenmayer/unison.
The tags are structured as ghcr.io/eugenmayer/unison:$UNISON_VERSION-$OCAML_VERSION-$ARCH
so for example
# this will pull the AMD or ARM version, depending on your current arch
docker pull ghcr.io/eugenmayer/unison:2.52.1-4.12.0
This image simply runs an unison server on the internal port 5000
with the specified user/uid. If the user/uid doesn't
exist, it is created/modified on startup.
You can also combine it with OSXFS as it's done in docker-sync native_osx.
The image is used by docker-sync by default, unless it is overridden using the configuration option <sync_strategy>_image in docker-sync.yml. The image uses the latest OCaml and Unison versions available at the time of release. Incase other versions needs to be used (which matches the versions used with docker-sync on the host), build a new docker-image-unison image as follows:
You can build your own image using
docker build --build-arg "OCAML_VERSION=<ocaml-version>" --build-arg "UNISON_VERSION=<unison-version>" -t custom-docker-image-unison .
where ocaml-version
is any OCaml version available as source-code here and unison-version
is any Unison version available as source code here.
Or for arm base builds change the image using BASE_IMAGE
docker build --build-arg "BASE_IMAGE=arm64v8/alpine:3.12" --build-arg "OCAML_VERSION=<ocaml-version>" --build-arg "UNISON_VERSION=<unison-version>" -t custom-docker-image-unison .
For example,
docker build --build-arg "OCAML_VERSION=4.12.0" --build-arg "UNISON_VERSION=2.52.1" -t custom-docker-image-unison .
The configuration in the docker-sync.yml would then be:
unison_image: 'custom-docker-image-unison'
A lot of credits go to mickaelperrin - most of the work has been done by him initially.
You can configure how unison runs by using the following ENV variables:
UNISON_SRC
th unison src - default is/app_sync
UNISON_DEST
th unison dest - default is/host_sync
APP_VOLUME
specifies the directory created in the container to store the synced files,/app_sync
by defaultOWNER_UID
specifies the ID of the user on which the unison process run and the owner of the synced files.MAX_INOTIFY_WATCHES
increases the limit of inotify watches if you need to sync folders with lots of files.UNISON_ARGS
Pass individual args to unison.UNISON_WATCH_ARGS
Pass individual watch args for unison
- Big thanks at mickaelperrin for putting hard work into getting this production ready.
What the others did, so: This docker image is licensed under GPLv3 because Unison is licensed under GPLv3 and is included in the image. See LICENSE.