Browse Source

Docker sapl 2 (#1023)

* Adiciona dDocker baseado em Alpine-Python3 com Ngnix e Gunicorn

* Atualiza docker-compose com gunicorn, ngnix e postgres

* Ajusta gitignore para ignorar postgres-data

* Adiciona script bash para conexao ao banco

* Ajusta busy-wait.sh script para sincronizar o banco(postgres) com a aplicação django no docker

* Add alias to sapldb

* Refazer Dockerfile

* Ajusta Dockerfile e docker-compose com entrypoint start.sh

* Ajusta start.sh

* Adiciona mais pontos de montagem.

* Coloca start.sh como executável: chmod +x start.sh

* Remove arquivo lixo

* Substitui gen-env.py por shell script puro

* Ajusta diretorio /var/interlegis/sapl e collect_static como volume no nginix

* Simplifica criação de diretórios.

* Adiciona ponto de montagem em postgres para importar dados

* Adiciona mais parâmetros de ambiente UNIX para entrypoint docker
pull/802/merge
Edward 8 years ago
committed by GitHub
parent
commit
96ce98f29d
  1. 4
      .gitignore
  2. 4
      .travis.yml
  3. 75
      Dockerfile
  4. 10
      busy-wait.sh
  5. 8
      config/env-sample
  6. 39
      config/nginx/sapl.conf
  7. 26
      docker-compose.yml
  8. 6
      docker-env.sh
  9. 1
      envfile
  10. 7
      genkey.py
  11. 10
      gunicorn_start.sh
  12. 2
      sapl/.env_test
  13. 1
      sapl/static/styles/app.css
  14. 1
      sapl/static/styles/compilacao.css
  15. 3
      scripts_docker/shell_sapl.sh
  16. 53
      start.sh

4
.gitignore

@ -92,4 +92,6 @@ collected_static
bower
bower_components
media
whoosh/
whoosh/
postgres-data/
data/

4
.travis.yml

@ -20,3 +20,7 @@ script:
- ./manage.py bower install
- py.test --create-db
# - ./test_and_check_qa.sh
addons:
hosts:
- 127.0.0.1 sapldb

75
Dockerfile

@ -1,53 +1,34 @@
FROM ubuntu:15.04
RUN locale-gen en_US.UTF-8
ENV LANG en_US.UTF-8
ENV LANGUAGE en_US:en
ENV LC_ALL en_US.UTF-8
RUN mkdir /sapl
RUN echo "deb http://archive.ubuntu.com/ubuntu/ vivid universe" | tee -a "/etc/apt/sources.list"
RUN \
apt-get update && \
apt-get install -y -f \
software-properties-common \
libpq-dev \
graphviz-dev \
graphviz \
build-essential \
git \
pkg-config \
python3-dev \
libxml2-dev \
libjpeg-dev \
libssl-dev \
libffi-dev \
libxslt1-dev \
python3-setuptools \
curl
# use python3 in pip
RUN easy_install3 pip lxml
# install nodejs
RUN DEBIAN_FRONTEND=noninteractive curl -sL https://deb.nodesource.com/setup_5.x | bash -
RUN DEBIAN_FRONTEND=noninteractive apt-get install -y nodejs
# install bower
RUN npm install -g bower
FROM alpine:3.5
ENV BUILD_PACKAGES postgresql-dev graphviz-dev graphviz build-base git pkgconfig \
python3-dev libxml2-dev jpeg-dev libressl-dev libffi-dev libxslt-dev nodejs py3-lxml \
py3-magic postgresql-client vim
RUN apk add --no-cache python3 && \
python3 -m ensurepip && \
rm -r /usr/lib/python*/ensurepip && \
pip3 install --upgrade pip setuptools && \
rm -r /root/.cache
RUN mkdir -p /var/interlegis/sapl &&\
apk add --update --no-cache $BUILD_PACKAGES && \
npm install -g bower
# Bower aceitar root
RUN touch /root/.bowerrc
RUN chmod 751 /root/.bowerrc
RUN echo "{ \"allow_root\": true }" >> /root/.bowerrc
RUN touch /root/.bowerrc \
&& chmod 751 /root/.bowerrc \
&& echo "{ \"allow_root\": true }" >> /root/.bowerrc \
&& npm cache clean
WORKDIR /var/interlegis/sapl/
ADD . /var/interlegis/sapl/
WORKDIR /sapl
COPY start.sh /var/interlegis/sapl/
ADD . /sapl
RUN chmod +x /var/interlegis/sapl/start.sh
RUN pip install -r requirements/dev-requirements.txt
RUN pip install --upgrade setuptools
RUN pip install -r /var/interlegis/sapl/requirements/requirements.txt --upgrade setuptools
# RUN python3 manage.py bower install
VOLUME ["/var/interlegis/sapl/data", "/var/interlegis/sapl/media", "/var/interlegis/sapl/collected_static"]
ENTRYPOINT ["/var/interlegis/sapl/start.sh"]

10
busy-wait.sh

@ -0,0 +1,10 @@
#!/bin/sh
while true; do
COUNT_PG=`psql --dbname=postgresql://sapl:sapl@sapldb/sapl -c '\l \q' | grep sapl | wc -l`
if ! [ "$COUNT_PG" -eq "0" ]; then
break
fi
echo "Esperando Database Setup"
sleep 10
done

8
config/env-sample

@ -0,0 +1,8 @@
DATABASE_URL = postgresql://postgres:@sapldb:/sapl
KEY
DEBUG = False
EMAIL_USE_TLS = True
EMAIL_PORT = 587
EMAIL_HOST = ''
EMAIL_HOST_USER = ''
EMAIL_HOST_PASSWORD = ''

39
config/nginx/sapl.conf

@ -0,0 +1,39 @@
upstream sapl_server {
server unix:/var/interlegis/sapl/run/gunicorn.sock fail_timeout=0;
}
server {
listen 80;
server_name sapl.test;
client_max_body_size 4G;
location /static/ {
alias /var/interlegis/sapl/collected_static/;
}
location /media/ {
alias /var/interlegis/sapl/media/;
}
location / {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_redirect off;
if (!-f $request_filename) {
proxy_pass http://sapl_server;
break;
}
}
error_page 500 502 503 504 /500.html;
location = /500.html {
root /var/interlegis/sapl/sapl/static/;
}
}

26
docker-compose.yml

@ -1,17 +1,31 @@
localhost:
server:
image: nginx:latest
ports:
- "80:80"
volumes:
- ./config/nginx:/etc/nginx/conf.d
- ./collected_static:/var/interlegis/sapl/collected_static
- ./media:/var/interlegis/sapl/media
volumes_from:
- web
sapldb:
image: postgres
environment:
POSTGRES_PASSWORD: sapl
POSTGRES_USER: sapl
POSTGRES_DB: sapl
PGDATA : /var/lib/postgresql/data/
volumes:
- ./postgres-data/data/:/var/lib/postgresql/data/
- ./data:/data-import
ports:
- "5532:5432"
web:
build: .
command: /bin/sh -c "/bin/sh busy-wait.sh && python3 manage.py bower install && python3 manage.py migrate && /bin/sh gunicorn_start.sh /sapl"
volumes:
- .:/sapl
ports:
- "8000:8000"
- .:/var/interlegis/sapl/
- ./data:/var/interlegis/sapl/data
- ./media:/var/interlegis/sapl/media
- ./collected_static:/var/interlegis/sapl/collected_static
links:
- localhost
- sapldb

6
docker-env.sh

@ -0,0 +1,6 @@
#/bin/bash
KEY=`python gen-key.py`
echo $KEY
sed -e "s/SECRET_KEY = None/SECRET_KEY = $KEY/g" config/env-sample

1
envfile

@ -0,0 +1 @@
EMAIL_HOST_USER=foo

7
genkey.py

@ -0,0 +1,7 @@
import random
def generate_secret():
return ''.join([random.SystemRandom().choice('abcdefghijklmnopqrstuvwxyz0123456789!@#$%^&*(-_=+)') for i in range(50)])
if __name__ == '__main__':
print(generate_secret())

10
gunicorn_start.sh

@ -12,23 +12,17 @@ then
fi
NAME="SAPL" # Name of the application (*)
DJANGODIR=/var/interlegis/sapl # Django project directory (*)
DJANGODIR=/var/interlegis/sapl/ # Django project directory (*)
SOCKFILE=/var/interlegis/sapl/run/gunicorn.sock # we will communicate using this unix socket (*)
USER=`whoami` # the user to run as (*)
GROUP=`whoami` # the group to run as (*)
NUM_WORKERS=9 # how many worker processes should Gunicorn spawn (*)
NUM_WORKERS=3 # how many worker processes should Gunicorn spawn (*)
# NUM_WORKERS = 2 * CPUS + 1
DJANGO_SETTINGS_MODULE=sapl.settings # which settings file should Django use (*)
DJANGO_WSGI_MODULE=sapl.wsgi # WSGI module name (*)
echo "Starting $NAME as `whoami` on base dir $SAPL_DIR"
# Activate the virtual environment
cd $DJANGODIR
source /var/interlegis/.virtualenvs/sapl/bin/activate
export DJANGO_SETTINGS_MODULE=$DJANGO_SETTINGS_MODULE
export PYTHONPATH=$DJANGODIR:$PYTHONPATH
# Create the run directory if it doesn't exist
RUNDIR=$(dirname $SOCKFILE)
test -d $RUNDIR || mkdir -p $RUNDIR

2
sapl/.env_test

@ -1,4 +1,4 @@
DATABASE_URL = postgresql://postgres:@localhost:/sapl
DATABASE_URL = postgresql://postgres:@sapldb:/sapl
SECRET_KEY=TravisTest
DEBUG=False
EMAIL_USE_TLS = True

1
sapl/static/styles/app.css

File diff suppressed because one or more lines are too long

1
sapl/static/styles/compilacao.css

File diff suppressed because one or more lines are too long

3
scripts_docker/shell_sapl.sh

@ -1,2 +1,3 @@
#!/bin/bash
docker run -ti sapl_web /bin/bash
docker run --rm -ti sapl_web /bin/sh

53
start.sh

@ -0,0 +1,53 @@
#!/bin/sh
create_env() {
# check if file exists
if [ -f "/var/interlegis/sapl/data/secret.key" ]; then
KEY=`cat /var/interlegis/sapl/data/secret.key`
else
KEY=`python3 genkey.py`
echo $KEY > data/secret.key
fi
# TODO: rename env-test-bash to .env
FILENAME="/var/interlegis/sapl/sapl/.env"
if [ -z "${DATABASE_URL:-}" ]; then
DATABASE_URL="postgresql://sapl:sapl@sapldb:5432/sapl"
fi
# ALWAYS replace the content of .env variable
# If want to conditionally create only if absent then use IF below
# if [ ! -f $FILENAME ]; then
touch $FILENAME
# explicitly use '>' to erase any previous content
echo "SECRET_KEY="$KEY > $FILENAME
# now only appends
echo "DATABASE_URL = "$DATABASE_URL >> $FILENAME
echo "DEBUG = ""${DEBUG-False}" >> $FILENAME
echo "EMAIL_USE_TLS = ""${USE_TLS-True}" >> $FILENAME
echo "EMAIL_PORT = ""${EMAIL_PORT-587}" >> $FILENAME
echo "EMAIL_HOST = ""${EMAIL_HOST-''}" >> $FILENAME
echo "EMAIL_HOST_USER = ""${EMAIL_HOST_USER-''}" >> $FILENAME
echo "EMAIL_HOST_PASSWORD = ""${EMAIL_HOST_PASSWORD-''}" >> $FILENAME
}
echo "creating .env file..."
create_env
echo "done."
# # python3 gen-env.py
python3 manage.py bower install
/bin/sh busy-wait.sh
python3 manage.py migrate
python3 manage.py collectstatic --no-input
python3 manage.py rebuild_index --noinput
/bin/sh gunicorn_start.sh
Loading…
Cancel
Save