How to run hinkskalle as a container (recommended) or local installation
Deployment with docker-compose
Get a docker-compose file. Why not this one: docker-compose.yml?
Apart from the application server listening on port 7660 this also starts:
- PostgreSQL Server for metadata (only available within the docker-compose network)
- Redis Server for background/periodic job execution
- an rq worker to execute jobs
- an rq-scheduler to manage periodic maintenance jobs
Configuration
See configuration for details
- run mkdir conf/
- Set up
- conf/config.json
- conf/hinkskalle.env
(change HINKSKALLE_BACKEND_URL, see below)
- conf/secrets.env
- conf/db_secrets.env
 
- check the image storage path in the docker-compose file, see below
Backend URL
Configure HINKSKALLE_BACKEND_URL to be the public URL of your server.
- for testing this will most likely be http://127.0.0.1:7600/
- behind a reverse proxy (recommended): the URL you are mapping to hinkskalle
- note that Hinkskalle does not speak https. If you would like to expose your server directly, this should be the servername and port, e.g. http://pkg.internal:7600/
Image Storage
All your images (or OCI layers) are stored in a directory somewhere on your filesystem. In share/deploy/docker-compose.yml The internal storage directory /mnt/images (configured in share/deploy/config/config.json is mounted from a docker volume. Other options would be:
- a network file system (with some caveats for performance)
- a local directory on your server (think of backups, available space)
- a docker volume (same)
Database Setup
With the default docker-compose file:
# start db server first to trigger database initialization
docker-compose up -d hinkdb
# installs database schema
docker-compose run --rm api flask db upgrade
# create admin user
docker-compose run --rm api flask localdb add-user \
  -u admin.hase \
  -p somethingonlyyouknow \
  -e admin@testha.se \
  -f Admin -l Hase \
  --admin
# create regular user (or use web interface)
docker-compose run --rm api flask localdb add-user \
  -u user.hase \
  -p alsosomethingfairlysecret \
  -e user@testha.se \
  -f User -l Hase
LDAP Setup (optional)
Initial sync all LDAP users:
docker-compose run --rm api flask ldap sync
Startup
- fire up whole stack with: docker-compose up -d
Reverse Proxy
The example docker-compose starts a backend server on port 7600. You will want to run it behind a reverse proxy serving via HTTPS (e.g. nginx, caddy, Apache, …).
Keyserver
If you would like to run your own keyserver put something like this in your docker-compose.yaml:
volumes:
  # ...
  hockeypuck_db:
  hockeypuck_data:
# ...
services:
  # ...
  hockeypuck:
    image: "ghcr.io/csf-ngs/hockeypuck"
    ports:
      - "11371:11371"
    depends_on:
      - hockeypuck_db
    volumes:
      - hockeypuck_data:/hockeypuck/data
  hockeypuck_db:
    image: postgres:12
    environment:
      - POSTGRES_USER=hkp
      - POSTGRES_DB=hkp
      - POSTGRES_PASSWORD=hkp ! <---  danger mouse
    volumes:
      - hockeypuck_db:/var/lib/postgresql/data
This will start an instance of Hockeypuck. The config variable KEYSERVER_URL should point to http://localhost:11371/.
Install from Source Code
- latest release from the release page and unpack
Required Python Packages
cd backend/
# with sqlite only
pip install .
# or with postgres
pip install '.[postgres]'
Singularity Binaries
Set up singularity according to the instructions on sylabs.io
It is required only for checking image signatures and showing the singularity definition file on the web.
The singularity binary should end up in $PATH so that Hinkskalle can find it.
/usr/local/bin, the default, is usually fine.
Configuration
Hinkskalle reads its configuration from JSON files. By default it looks for
- conf/config.json
- conf/secrets.json(optional)
My recommendation is to put passwords etc. in an extra file (which is in .gitignore) to make it harder to accidentally commit your credentials.
See configuration for valid configuration options.