- Install docker
- Init swarm:
docker swarm init
- Add docker-configs from
fairdata-docker
repo - Update
/etc/hosts
with0.0.0.0 metax.fd-dev.csc.fi
- Deploy with
docker stack deploy -c docker-compose.yml --resolve-image=always --with-registry-auth metax-dev
- Init Metax
docker exec $(docker ps -q -f name=metax-dev_metax-web) python manage.py first_time_setup
After installing Docker prerequisites, Initialize the Swarm:
docker swarm init
Append your local /etc/hosts
file with:
0.0.0.0 metax.fd-dev.csc.fi
The default stack requires docker-configurations that can be found from fairdata-docker
repository.
If there is no access to that repo, refer the next section.
When the required configurations are created, the stack can be deployed from the repository root with:
docker stack deploy -c docker-compose.yml --resolve-image=always --with-registry-auth metax-dev
After all the services has been started, Metax is available from metax.fd-dev.csc.fi
. This stack contains the common Fairdata nginx proxy.
NOTE: Docker for Mac has a bug that prevents the required configurations to be deployed to metax-web container. To work around this, refer the Required environmental variables
section in README
Development setup without pre-required docker-configurations can be run with:
docker stack deploy -c config-swap-stack.yml --resolve-image=always --with-registry-auth metax-dev
After all the services has been started, Metax is available from 0.0.0.0:8008
. This stack allows the environment
variables to be changed without re-deploying the whole stack. To add certain docker-config to metax-web container:
docker service update --config-add source=<CONFIG-NAME>,target=/code/metax_api/settings/.env metax-dev_metax-web
To change existing configuration in metax-web container:
docker service update --config-rm <CONFIG-NAME> --config-add source=<NEW-CONFIG-NAME>,target=/code/metax_api/settings/.env metax-dev_metax-web
Docker images needed in the development can be built with the following commands:
docker build -t fairdata-docker.artifactory.ci.csc.fi/fairdata-metax-web .
docker build -t fairdata-docker.artifactory.ci.csc.fi/fairdata-metax-httpd -f httpd.dockerfile .
docker build -t fairdata-docker.artifactory.ci.csc.fi/fairdata-metax-sphinx -f sphinx.dockerfile .
Ensure that you are logged in to Artifactory:
docker login fairdata-docker.artifactory.ci.csc.fi
Push commands for docker images:
docker push fairdata-docker.artifactory.ci.csc.fi/fairdata-metax-web
docker push fairdata-docker.artifactory.ci.csc.fi/fairdata-metax-httpd
docker push fairdata-docker.artifactory.ci.csc.fi/fairdata-metax-sphinx
To run Metax management commands, locate the running metax-dev_metax-web container (can be done with docker container ls
)
and open terminal inside it with:
docker exec -it <container-name> bash
The stack also contains a Sphinx autobuild server for documentation development. More specific instructions can be found from here.