mirror of https://github.com/interlegis/sapl.git
134 lines
3.4 KiB
134 lines
3.4 KiB
==============================
|
|
Instruções para fazer o Deploy
|
|
==============================
|
|
|
|
Para efeitos deste doc, foram consideradas as tecnologias NGINX + GUNICORN para servir a aplicação Django SAPL.
|
|
|
|
O NGINX é o servidor WEB, e o GUNICORN é o servidor da aplicação para o servidor WEB.
|
|
|
|
|
|
|
|
É altamente recomendável que para produção o SAPL não seja executado em modo debug.
|
|
Para isso edite o arquivo ``.env`` criado anteriormente em::
|
|
|
|
sudo nano /var/interlegis/sapl/sapl/.env
|
|
|
|
alterando o variável DEBUG para false::
|
|
|
|
DEBUG = False
|
|
|
|
Entrar no ambiente virtual::
|
|
|
|
workon sapl
|
|
|
|
|
|
Arquivos Estáticos
|
|
------------------
|
|
Com o ambiente em produção, os arquivos estáticos devem ser servidos pelo web service, em nosso caso o `NGINX`, logo para ter acesso aos arquivos primeiro devemos rodar o seguinte comando::
|
|
|
|
./manage.py compilescss
|
|
|
|
para que os arquivos SASS/SCSS sejam compilados em arquivos .css em ambiente de produção, e em seguida rode::
|
|
|
|
./manage.py collectstatic --no-input --clear
|
|
|
|
para coletar todos os arquivos estáticos do projeto e guarda-los no diretório definido em `STATIC_ROOT`, que será também o diretório no qual o `NGINX` irá referenciar para a aplicação.
|
|
|
|
Instalando Pacotes
|
|
------------------
|
|
|
|
Instalar o NGINX::
|
|
|
|
sudo apt-get install nginx
|
|
|
|
|
|
Instalar o Gunicorn::
|
|
|
|
sudo pip3 install gunicorn
|
|
|
|
|
|
Preparando o NGINX
|
|
------------------
|
|
sudo nano /etc/nginx/sites-available/sapl31.conf::
|
|
|
|
upstream ENDERECO_SITE {
|
|
server unix:/var/interlegis/sapl/run/gunicorn.sock fail_timeout=0;
|
|
}
|
|
|
|
server {
|
|
|
|
listen 80;
|
|
server_name ENDERECO_SITE;
|
|
|
|
client_max_body_size 4G;
|
|
|
|
access_log /var/log/nginx-access.log;
|
|
error_log /var/log/nginx-error.log;
|
|
|
|
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://ENDERECO_SITE;
|
|
break;
|
|
}
|
|
}
|
|
|
|
# Error pages
|
|
error_page 500 502 503 504 /500.html;
|
|
location = /500.html {
|
|
root /var/interlegis/sapl/sapl/static/;
|
|
}
|
|
}
|
|
|
|
|
|
Criar link simbólico para ativar o site::
|
|
|
|
sudo ln -s /etc/nginx/sites-available/sapl31.conf /etc/nginx/sites-enabled/sapl3
|
|
|
|
Reiniciar o nginx::
|
|
|
|
sudo service nginx restart
|
|
|
|
|
|
Preparando o Gunicorn
|
|
---------------------
|
|
Na raiz do Projeto sapl, existe o arquivo chamado gunicorn_start.sh
|
|
|
|
Para definir o parametro NUM_WORKERS utilize a seguinte fórmula: 2 * CPUs 1.
|
|
Para uma máquina de CPU única o valor seria 3
|
|
|
|
|
|
Para rodar o gunicorn::
|
|
|
|
workon sapl
|
|
|
|
/var/interlegis/sapl/.gunicorn_start.sh
|
|
|
|
|
|
|
|
#Referências.
|
|
|
|
http://michal.karzynski.pl/blog/2013/06/09/django-nginx-gunicorn-virtualenv-supervisor/
|
|
|
|
Para multiplas aplicações Django.
|
|
|
|
http://michal.karzynski.pl/blog/2013/10/29/serving-multiple-django-applications-with-nginx-gunicorn-supervisor/
|
|
|
|
Compilar arquivos SASS/SCSS
|
|
|
|
https://github.com/jrief/django-sass-processor#offline-compilation
|
|
https://github.com/jrief/django-sass-processor/issues/34#issuecomment-252611103
|
|
|
|
Deploy Arquivos Estáticos
|
|
|
|
https://docs.djangoproject.com/pt-br/1.11/howto/static-files/deployment/
|
|
|