Containerised CKAN, Postgres, Solr using Docker.
Use cases:
- Replicating an existing database, then running a dev CKAN server.
- Running production CKAN with an existing database.
This file contains the config for CKAN, including connection urls.
File location:
- Development: in the repo under
ckan-container/config/ckan.ini
. - Production:
$HOME/ckan/${BRANCH_NAME}.ini
for the deployment user.
To generate an example ckan.ini
file via terminal:
docker run --rm --entrypoint=sh \
registry-gitlab.wsl.ch/envidat/ckan-container/ckan:2.10.1-main \
-c "ckan generate config ckan.ini && cat ckan.ini"
The easiest way is to run using the interactive script.
Alternativly, follow the steps below.
- During development dummy credentials are used for Solr.
- In production we must set the Solr container user and password.
The SOLR_CKAN_PASS must match the credentials specified in
ckan.ini
.
.solr.env contains credentials of the Solr instance.
SOLR_ADMIN_PASS=xxxx
SOLR_CKAN_PASS=xxxx
docker compose -f docker-compose.main.yml up -d
Note: the
docker-compose.main.yml
is made to work with an external database, and has no db service specified.
- Change versions, registry connections, etc.
This is the default configuration when running docker-compose.yml
.
.db.env contains credentials of the remote database to replicate.
DB_HOST=xxxxxx.wsl.ch
DB_CKAN_NAME=envidat
DB_USER=xxenvidat
DB_PASS=xxxxxx
DB_DOI_NAME=envidat_doi
- Build the images with
docker compose build
. - Then run with
docker compose up -d
.
The database will be replicated when the containers start.
Alternatively, a fresh database can be used for CKAN.
To do this, run with this command instead:
DB_ENV_FILE=/dev/null docker compose up -d
GIT_REPO=https://github.com/EnviDat/ckanext-cloudstorage.git
GIT_BRANCH=main
docker exec -it -u root:root ckan \
bash -c 'apt update \
&& apt install git -y --no-install-recommends'
docker exec -it -u root:root ckan \
pip install --upgrade --no-deps --force-reinstall \
"git+${GIT_REPO}@${GIT_BRANCH}"
- Create a symlink to the code:
ln -s ../ckan/ckan ./ckan
ln -s ../ckanext-passwordless_api/ckanext/passwordless_api ./ckanext/passwordless_api
- Mount the directories in your container:
# docker-compose.yaml
---
volumes:
- ../ckan:/usr/lib/ckan/.local/lib/python3.10/site-packages/ckan
- ./ckanext/passwordless_api:/usr/lib/ckan/.local/lib/python3.10/site-packages/ckanext/passwordless_api
- Helm deploy (see chart directory README.md with values and secrets).
- Modify ckan.ini secret (example parameters below):
beaker.session.secret = xxx
app_instance_uuid = xxx-xxx-xxx-xxx-xxx
ckan.site_url = ingress_host_url
ckan.site_description = EnviDat Prod
ckan.storage_path = /data/ckan/default
ckan.cors.origin_whitelist = envidat.ch frontend.envidat.ch
sqlalchemy.url = SERVICE_NAME.NAMESPACE.svc.cluster.local:5432
solr_url = SERVICE_NAME.NAMESPACE.svc.cluster.local:8983
solr_password = xxx
ckan.redis.url = SERVICE_NAME.NAMESPACE.svc.cluster.local:6379
ckanext.cloudstorage.container_name = envidat-dev
ckanext.cloudstorage.driver_options = {"key": "xxx", "secret": "xxx", "host": "https://minio.envidat.ch"}
ckanext.cloudstorage.use_secure_urls = 0
recaptcha.keys = xxx
The goal of this script is to start both the EnviDat backend and frontend interactively.
It achieves three things:
- Setting up the environment, including installing Docker.
- Setting the configuration required to run the containers.
- Running the containers.
curl -LO https://gitlabext.wsl.ch/EnviDat/ckan-container/-/jobs/21147/artifacts/raw/envidat
chmod +x envidat
sudo mv envidat /usr/local/bin/
envidat
This will add the envidat program to your PATH for easy execution.
. scripts/envidat-in-a-box.sh
source scripts/envidat-in-a-box.sh