This Docker image is for eLabFTW. It runs four services:
- nginx: the webserver
- php-fpm: to handle requests to PHP files
- chronos: executes tasks on a schedule (similar to a cronjob)
- invoker: executes tasks asynchronously (useful for exports for instance)
These services are managed by s6-overlay and are all heavily customized for running eLabFTW.
Tags, in the context of Docker images, are what comes after the image name (elabftw/elabimg), separated by a colon. If you leave it empty, it defaults to latest, which will point to the latest stable release. But it is recommended to explicitly define the version you wish to run, e.g.: elabftw/elabimg:5.3.4.
When defining which image version to use, you can use different tags:
- x.y.z: the actual explicit version: recommended
- stable: the latest stable version
- latest: the latest stable version
- edge: the latest version, can be a stable version or an alpha or beta, whatever is present on- masterbranch of eLabFTW
- hypernext: this is the dev version, built on a "push" event as well as on a daily schedule, it must never be deployed outside of a testing environment
Set the ELABFTW_VERSION build arg to a tagged release or a branch. The latest stable version can be found here.
docker build --build-arg ELABFTW_VERSION=X.Y.Z -t elabftw/elabimg:X.Y.Z .For dev, add --build-arg BUILD_ALL=0 to skip the installation of dependencies and building of assets, because the folder will be bind-mounted to your host anyway.
An example configuration file for docker-compose can be fetched like this:
curl -so docker-compose.yml "https://get.elabftw.net/?config"After downloading the configuration file, open it in your preferred text editor to modify settings as necessary.
For usage of eLabFTW, see documentation.
If for some reason you wish to reload a service without restarting the container (for instance when trying configuration changes), you can use reload:
# reload php and nginx
reload
# reload only php
reload php
# reload only nginx
reload nginxIf there is a CVE fixed upstream, delete build cache with:
gh cache delete --allRequires GitHub CLI: https://cli.github.com/