Obico is a community-built, open-source smart 3D printing platform used by makers, enthusiasts, and tinkerers around the world.
We use Docker manifest for cross-platform compatibility. More details can be found on Docker's website.
To obtain the appropriate image for your architecture, simply pull ghcr.io/imagegenius/obico:latest
. Alternatively, you can also obtain specific architecture images by using tags.
This image supports the following architectures:
Architecture | Available | Tag |
---|---|---|
x86-64 | ✅ | amd64-<version tag> |
arm64 | ❌ | |
armhf | ❌ |
This image offers different versions via tags. Be cautious when using unstable or development tags, and read their descriptions carefully.
Tag | Available | Description |
---|---|---|
latest | ✅ | Latest obico-server release, only supports CPU for machine learning. |
cuda | ✅ | Latest obico-server release with support for GPU (CUDA) acceleration. |
The WebUI can be found at http://your-ip:3334
.
**After starting the container, it is important to configure obico-server (Django) to ensure that all assets are properly loaded.
Follow steps 1-2 under 'Login as Django admin' and 'Configure Django site' in the Obico Server Configuration guide closely. These steps will guide you through setting up login credentials and configuring the domain name to match the IP used to access the container, or your FQDN if using a reverse proxy.
You can also use environment variables to set various configurations, such as email settings. A list of available environment variables can be found here.
Obico requires that you have Redis setup externally.
Follow these steps if you need help setting up Redis.
Redis can be ran within the container using a docker-mod or you can use an external Redis server/container.
If you don't need to use Redis elsewhere add this environment variable: DOCKER_MODS=imagegenius/mods:universal-redis
, and set REDIS_URL
to redis://localhost:6379
.
Or within a seperate container:
docker run -d \
--name=redis \
-p 6379:6379 \
redis
Obico do not publish versioning for obico-server, so we use the latest commit hash to identify the current version.
Example snippets to start creating a container:
---
services:
obico:
image: ghcr.io/imagegenius/obico:latest
container_name: obico
environment:
- PUID=1000
- PGID=1000
- TZ=Etc/UTC
- REDIS_URL=redis://<ip>:<port>
- HOST_IP=<192.168.0.5:3334>/<example.com>
volumes:
- path_to_appdata:/config
ports:
- 3334:3334
restart: unless-stopped
Docker CLI (Click here for more info)
docker run -d \
--name=obico \
-e PUID=1000 \
-e PGID=1000 \
-e TZ=Etc/UTC \
-e REDIS_URL=redis://<ip>:<port> \
-e HOST_IP=<192.168.0.5:3334>/<example.com> \
-p 3334:3334 \
-v path_to_appdata:/config \
--restart unless-stopped \
ghcr.io/imagegenius/obico:latest
To configure the container, pass variables at runtime using the format <external>:<internal>
. For instance, -p 8080:80
exposes port 80
inside the container, making it accessible outside the container via the host's IP on port 8080
.
Parameter | Function |
---|---|
-p 3334 |
WebUI Port |
-e PUID=1000 |
UID for permissions - see below for explanation |
-e PGID=1000 |
GID for permissions - see below for explanation |
-e TZ=Etc/UTC |
Specify a timezone to use, see this list. |
-e REDIS_URL=redis://<ip>:<port> |
Redis URL, eg. redis://192.168.1.2:6379 |
-e HOST_IP=<192.168.0.5:3334>/<example.com> |
Domain/IP+Port used to access the frontend, if incorrect you will get an error 500! |
-v /config |
Contains django database, logs and timelapses |
All of our images allow overriding the default umask setting for services started within the containers using the optional -e UMASK=022 option. Note that umask works differently than chmod and subtracts permissions based on its value, not adding. For more information, please refer to the Wikipedia article on umask here.
To avoid permissions issues when using volumes (-v
flags) between the host OS and the container, you can specify the user (PUID
) and group (PGID
). Make sure that the volume directories on the host are owned by the same user you specify, and the issues will disappear.
Example: PUID=1000
and PGID=1000
. To find your PUID and PGID, run id user
.
$ id username
uid=1000(dockeruser) gid=1000(dockergroup) groups=1000(dockergroup)
Most of our images are static, versioned, and require an image update and container recreation to update the app. We do not recommend or support updating apps inside the container. Check the Application Setup section for recommendations for the specific image.
Instructions for updating containers:
- Update all images:
docker-compose pull
- or update a single image:
docker-compose pull obico
- or update a single image:
- Let compose update all containers as necessary:
docker-compose up -d
- or update a single container:
docker-compose up -d obico
- or update a single container:
- You can also remove the old dangling images:
docker image prune
- Update the image:
docker pull ghcr.io/imagegenius/obico:latest
- Stop the running container:
docker stop obico
- Delete the container:
docker rm obico
- Recreate a new container with the same docker run parameters as instructed above (if mapped correctly to a host folder, your
/config
folder and settings will be preserved) - You can also remove the old dangling images:
docker image prune
- 09.01.25: - improve HOST_IP instructions
- 29.09.23: - precompile darknet
- 29.06.23: - create seperate cuda branch
- 23.03.23: - add service checks
- 05.03.23: - rollback moonraker (breaking upstream update)
- 23.01.23: - BREAKING: removed redis
- 14.01.23: - Update to s6v3
- 05.01.23: - Initial Working Release.
- 04.01.23: - Initial Release.