Merge pull request #18 from pyaillet/master

#13 Migration from Fig to Docker-compose
This commit is contained in:
Clément Mouchet 2015-04-23 18:51:39 +01:00
commit 75851cf0d3
5 changed files with 106 additions and 105 deletions

View File

@ -7,14 +7,14 @@ Developing and deploying CKAN with Docker
# Intro # Intro
Dockerfiles, Fig service definition & Vagrantfile to develop & deploy CKAN, Postgres, Solr & datapusher using Docker. Dockerfiles, Docker-compose service definition & Vagrantfile to develop & deploy CKAN, Postgres, Solr & datapusher using Docker.
Docker containers included: Docker containers included:
- CKAN (should work with any version 2.x) - CKAN (should work with any version 2.x)
- Postgres (Postgres 9.3 and PostGIS 2.1, CKAN datastore & spatial extension supported) - Postgres (Postgres 9.3 and PostGIS 2.1, CKAN datastore & spatial extension supported)
- Solr (4.10.1, custom schemas & spatial extension supported) - Solr (4.10.1, custom schemas & spatial extension supported)
- Fig _[optional]_ (to manage the containers) - Docker-compose _[optional]_ (to manage the containers)
- Data _[optional]_ (to store Postgres data & CKAN FileStore separately) - Data _[optional]_ (to store Postgres data & CKAN FileStore separately)
@ -29,7 +29,7 @@ Other contrib containers:
|Name |Version |Comment | |Name |Version |Comment |
|:--------------|:-------------:|:----------------------------------------------| |:--------------|:-------------:|:----------------------------------------------|
|Docker |>= 1.3 |works with Boot2docker 1.3 | |Docker |>= 1.3 |works with Boot2docker 1.3 |
|Fig |>= 1.0 |on the host or with Dockerfile provided | |Docker-compose |>= 1.1.0 |on the host or with Dockerfile provided |
|Vagrant |>= 1.6 |if you intend to use Vagrant | |Vagrant |>= 1.6 |if you intend to use Vagrant |
|OS |any |as long as you can run Docker 1.3 | |OS |any |as long as you can run Docker 1.3 |
@ -59,12 +59,12 @@ Other contrib containers:
├── docker ├── docker
│   ├── ckan │   ├── ckan
│   ├── data │   ├── data
│   ├── fig │   ├── compose
│   ├── nginx │   ├── nginx
│   ├── insecure_key (baseimage insecure SSH key) │   ├── insecure_key (baseimage insecure SSH key)
│   ├── postgres │   ├── postgres
│   └── solr │   └── solr
├── fig.yml (CKAN services definition) ├── docker-compose.yml (CKAN services definition)
└── vagrant └── vagrant
└── docker-host (Linux Docker host if required) └── docker-host (Linux Docker host if required)
@ -122,7 +122,7 @@ The Solr container runs version 4.10.1. This can easily be changed by customisin
By detault the `schema.xml` of the upstream version (2.3) is copied in the container. This can be overriden at runtime by mounting it as a volume. By detault the `schema.xml` of the upstream version (2.3) is copied in the container. This can be overriden at runtime by mounting it as a volume.
This default path of the volume is `<path to>/_src/ckan/ckan/config/solr/schema.xml` so it mounts the schema corresponding to your version of CKAN. This default path of the volume is `<path to>/_src/ckan/ckan/config/solr/schema.xml` so it mounts the schema corresponding to your version of CKAN.
For example for Fig: For example for Docker-compose:
solr: solr:
build: docker/solr build: docker/solr
@ -133,7 +133,7 @@ For example for Fig:
volumes: volumes:
- <path to>/_src/ckan/ckan/config/solr/schema.xml:/opt/solr/example/solr/ckan/conf/schema.xml - <path to>/_src/ckan/ckan/config/solr/schema.xml:/opt/solr/example/solr/ckan/conf/schema.xml
If you need a custom schema, put it in `<full path to>/_solr` and change the path in the fig or vagrant file. If you need a custom schema, put it in `<full path to>/_solr` and change the path in the docker-compose or vagrant file.
volumes: volumes:
- <path to>/_solr/schema.xml:/opt/solr/example/solr/ckan/conf/schema.xml - <path to>/_solr/schema.xml:/opt/solr/example/solr/ckan/conf/schema.xml
@ -144,18 +144,18 @@ The container is cross version compatible. You need mount the appropriate `schem
Read the [ckanext-spatial documentation](http://docs.ckan.org/projects/ckanext-spatial/en) to add the required fields to your Solr schema if you use ckanext-spatial Read the [ckanext-spatial documentation](http://docs.ckan.org/projects/ckanext-spatial/en) to add the required fields to your Solr schema if you use ckanext-spatial
##### Fig Dockerfile ##### Docker-compose Dockerfile
The Fig container runs Fig version `1.0.1` & the latest Docker within a container. The Docker-compose container runs the latests Docker-compose & Docker within a container.
The Docker socket needs to be mounted as a volume to control Docker on the host. A source folder must be mounted to access the fig definition The Docker socket needs to be mounted as a volume to control Docker on the host. A source folder must be mounted to access the docker-compose definition
see docker/Fig/Readme to find out how to use see docker/compose/Readme to find out how to use
#### Vagrantfile #### Vagrantfile
Defines VMs provided by Docker, a Virtual Box docker-host is used if the host can't run Docker containers natively. This is an alternative to Boot2Docker. Defines VMs provided by Docker, a Virtual Box docker-host is used if the host can't run Docker containers natively. This is an alternative to Boot2Docker.
#### fig.yml #### docker-compose.yml
Defines the set of services required to run CKAN. Read the [fig.yml reference](http://www.fig.sh/yml.html) to understand and edit. Defines the set of services required to run CKAN. Read the [docker-compose.yml reference](http://docs.docker.com/compose/yml/) to understand and edit.
@ -164,29 +164,29 @@ Defines the set of services required to run CKAN. Read the [fig.yml reference](h
1. Clone your code in the `_src` directory (see _src/README) 1. Clone your code in the `_src` directory (see _src/README)
2. Clone the datapusher in `_service-provider` (see _service-provider/README) 2. Clone the datapusher in `_service-provider` (see _service-provider/README)
3. Set the full path of the volumes in fig.yml 3. Set the full path of the volumes in docker-compose.yml
4. Run `up` with Fig or Vagrant 4. Run `up` with Docker-compose or Vagrant
## Using Fig (recommended) ## Using Docker-compose (recommended)
#### Option 1: Fig is installed on the Docker host #### Option 1: Docker-compose is installed on the Docker host
_If you have if >= 1.0 installed, just type_ _If you have it installed, just type_
fig up docker-compose up
#### Option 2: Using the fig container #### Option 2: Using the docker-compose container
_Otherwise, you can use the container provided_ _Otherwise, you can use the container provided_
Build fig the fig container Build the Docker-compose container
docker build --tag="fig_container" docker/fig docker build --tag="dockercompose_container" docker/compose
Run it Run it
docker run -it -d --name="fig-ckan" -p 2375 -v /var/run/docker.sock:/tmp/docker.sock -v $(pwd):/src fig_container docker run -it -d --name="dockercompose-ckan" -p 2375 -v /var/run/docker.sock:/tmp/docker.sock -v $(pwd):/src dockercompose_container
_In the fig container fig won't work with relative path, because the mount namespace is different, you need to change the relative path to absolute path_ _In the Docker-compose container docker-compose won't work with relative path, because the mount namespace is different, you need to change the relative path to absolute path_
for example, change the `./`: for example, change the `./`:
@ -198,9 +198,9 @@ to an absolute path to you ckan-docker directory: `/Users/username/git/ckan/cka
volumes: volumes:
- /Users/username/git/ckan/ckan-docker/_src:/usr/lib/ckan/default/src - /Users/username/git/ckan/ckan-docker/_src:/usr/lib/ckan/default/src
Build & Run the services defined in `fig.yml` Build & Run the services defined in `docker-compose.yml`
docker exec -it fig-ckan fig up docker exec -it dockercompose-ckan docker-compose up
If you are using boot2docker, add entries in your hosts file e.g. `192.168.59.103 ckan.localdomain` If you are using boot2docker, add entries in your hosts file e.g. `192.168.59.103 ckan.localdomain`
@ -235,7 +235,7 @@ SSH insecure key can be disabled by removing the `--enable-insecure-key` option
## Managing Docker images & containers ## Managing Docker images & containers
You should use fig to manage your containers & images, this will ensure they are started/stopped in order You should use docker-compose to manage your containers & images, this will ensure they are started/stopped in order
If you want to quickly remove all untagged images: If you want to quickly remove all untagged images:
@ -279,5 +279,5 @@ Both examples show that development dependencies should only be installed in the
# Sources # Sources
- [Docker](https://www.docker.com) - [Docker](https://www.docker.com)
- [Fig](http://www.fig.sh) - [Docker-compose](http://docs.docker.com/compose/)
- [Vagrant Docker provider](https://docs.vagrantup.com/v2/docker/index.html) - [Vagrant Docker provider](https://docs.vagrantup.com/v2/docker/index.html)

View File

@ -8,10 +8,11 @@ RUN locale-gen en_US.UTF-8 && \
RUN apt-get -qq update RUN apt-get -qq update
# Install required packages # Install required packages
RUN DEBIAN_FRONTEND=noninteractive apt-get -qq -y install curl RUN DEBIAN_FRONTEND=noninteractive apt-get -qq -y install \
python-pip
RUN curl -sSL https://get.docker.com/ | sh
RUN curl -L https://github.com/docker/fig/releases/download/1.0.1/fig-`uname -s`-`uname -m` > /usr/local/bin/fig; chmod +x /usr/local/bin/fig RUN pip install -U docker-compose
ENV DOCKER_HOST unix:///tmp/docker.sock ENV DOCKER_HOST unix:///tmp/docker.sock
WORKDIR /src WORKDIR /src

74
docker/compose/README.md Normal file
View File

@ -0,0 +1,74 @@
Docker-compose
==============
The docker-compose container runs the latests docker-compose & Docker within a container.
# Usage:
The Docker socket needs to be mounted as a volume to control Docker on the host. A source folder must be mounted to access the docker-compose definition
## Build & Run
_Move to the `ckan-docker` directory_
- Build it:
_Build the Docker image from `docker/compose/Dockerfile`, and call it "dockercompose_container"_
docker build --tag="dockercompose_container" docker/fig
- Run it:
_Start the a container based on the `dockercompose_container` Docker image_
docker run -it -d --name="dockercompose-ckan" -p 2375 -v /var/run/docker.sock:/tmp/docker.sock -v $(pwd):/src dockercompose_container
- Set the source volume path to yours.
_In the docker-compose container docker-compose won't work with relative path, because the mount namespace is different, you need to change the relative path to absolute path_
for example, change the `./`:
volumes:
- ./_src:/usr/lib/ckan/default/src
to an absolute path to you ckan-docker directory: `/Users/username/git/ckan/ckan-docker/`
volumes:
- /Users/username/git/ckan/ckan-docker/_src:/usr/lib/ckan/default/src
- Build the Docker images & run the containers:
Send the `docker-compose up` command to the docker-compose container
docker exec -it dockercompose-ckan docker-compose up
## Using the Docker-compose container
You can use any docker-compose command by pre-pending the `docker exec -it dockercompose-ckan` command to any docker-compose command
### build & start / recreate
docker exec -it dockercompose-ckan docker-compose up
### stop it
docker exec -it dockercompose-ckan docker-compose stop
### start it
docker exec -it dockercompose-ckan docker-compose start
### delete the containers
docker exec -it dockercompose-ckan docker-compose rm
### build new images
docker exec -it dockercompose-ckan docker-compose build
### logs
docker exec -it dockercompose-ckan docker-compose logs

View File

@ -1,74 +0,0 @@
Fig
===
The Fig container runs Fig version 1.0 & the latest Docker within a container.
# Usage:
The Docker socket needs to be mounted as a volume to control Docker on the host. A source folder must be mounted to access the fig definition
## Build & Run
_Move to the `ckan-docker` directory_
- Build it:
_Build the Docker image from `docker/fig/Dockerfile`, and call it "fig_container"_
docker build --tag="fig_container" docker/fig
- Run it:
_Start the a container based on the `fig_container` Docker image_
docker run -it -d --name="fig-ckan" -p 2375 -v /var/run/docker.sock:/tmp/docker.sock -v $(pwd):/src fig_container
- Set the source volume path to yours.
_In the fig container fig won't work with relative path, because the mount namespace is different, you need to change the relative path to absolute path_
for example, change the `./`:
volumes:
- ./_src:/usr/lib/ckan/default/src
to an absolute path to you ckan-docker directory: `/Users/username/git/ckan/ckan-docker/`
volumes:
- /Users/username/git/ckan/ckan-docker/_src:/usr/lib/ckan/default/src
- Build the Docker images & run the containers:
Send the `fig up` command to the fig container
docker exec -it fig-ckan fig up
## Using the Fig container
You can use amy fig command by pre-pending the `docker exec -it fig-ckan` command to any fig command
### build & start / recreate
docker exec -it fig-ckan fig up
### stop it
docker exec -it fig-ckan fig stop
### start it
docker exec -it fig-ckan fig start
### delete the containers
docker exec -it fig-ckan fig rm
### build new images
docker exec -it fig-ckan fig build
### logs
docker exec -it fig-ckan fig logs