Skip to content

Latest commit

 

History

History
163 lines (97 loc) · 6.51 KB

Instalação.md

File metadata and controls

163 lines (97 loc) · 6.51 KB

Essa é a documentação básica de instalação (deploy) timtec. Para informações sobre requisitos e dependências, veja o README.md.

Ubuntu 14.04 / 16.04 e Debian 7.7 / 8.0

Para usar o TIM Tec em produção sugerimos uma arquitetura usando o nginx como servidor web e o uwsgi como proxy.

Na pasta scripts, há um shell script que executa exatamente os passos a seguir. Se tiver pressa, olhe os scripts bootstrap-ubuntu.sh e production-ubuntu.sh.

Sugerimos que o usuário usado para fazer a instalação não seja o root. Aqui, o usuário que está fazendo a instalação é o timtec. Assim, nos comandos abaixo, substitua o nome do usuário pelo que você estiver usando. Os scripts possuem uma variável para definir o usuário que executará o proxy (wsgi). Caso use um usuário diferente, olhe o arquivo Makefile e faça as alterações necessárias.

Este tutorial pressupões que você esteja logado com o usuário timtec-production, que ele esteja no grupo sudo.

É possível verificar se o usuário timtec-production existe através do comando:

grep timtec /etc/passwd

Caso o usuário exista, o comando acima deve retornar uma linha semelhante a seguinte:

timtec:x:999:999::/home/timtec:

Caso não exista é possível criá-lo com:

$ sudo useradd --groups sudo --create-home timtec

Depois mude a senha:

$ sudo passwd timtec

Se você estiver usando Debian, pode acontecer do sistema criar uma instância do novo usuário com acesso a um terminal sh. Se você quiser usar o bash (terminal mais completo e com mais funcionalidades), você pode alterar essa informação no arquivo de configuração de usuários. Proceda da seguinte maneira:

  1. Abra o arquivo /etc/passwd e verifique a linha onde está o usuário timtec. Você pode ver uma linha assim:

    timtec:x:1001:1001::/home/timtec:/bin/sh

  2. Repare que a linha tem indicação para o terminal sh. Mude para bash e salve o arquivo com a linha desta maneira (use vim, nano ou qualquer editor de sua preferência):

    timtec:x:1001:1001::/home/timtec:/bin/bash

Obtendo o código

Dentro da home do usuário, primeiro vamos instalar o git e clonar o repositório

$ sudo apt-get update
$ sudo apt-get install git
$ git clone https://github.com/hacklabr/timtec.git

Em seguida, escolha a versão desejada e atualize o código para ela com o comando abaixo. Aqui você encontra uma lista de versões do TIMTec: https://github.com/hacklabr/timtec/releases

cd timtec
git checkout <tag-da-versão>

Substitua a tag da versão por uma tag do git válida. Ex: git checkout v4.0

Dependências

Primeiro, vamos instalar as dependências:

$ sudo apt-get update
$ sudo apt-get install -y libpq-dev libjpeg-dev libpng12-dev build-essential python-dev gettext python-virtualenv

Instalando o nodejs

Ubuntu

sudo apt-get install -y nodejs npm

Diferente de todas as outras distribuições, o ubuntu usa o comando node para o nodejs por padrão, então vamos fazer isso:

sudo update-alternatives --install /usr/bin/node node /usr/bin/nodejs 10

Debian

# TODO: atualizar este endereço
sudo apt-get install curl
sudo curl -sL https://deb.nodesource.com/setup | bash -
sudo apt-get install nodejs

Mais informações neste link

Banco de dados

Recomendamos o postgreSQL, mas o django suporta outros bancos de dados relacionais.

$ sudo apt-get install -y postgresql
$ sudo su - postgres -c "createuser -d timtec"
$ createdb --encoding "UTF-8" --locale "pt_BR.UTF-8" timtec

obs: caso ocorra algum problema relacionado a locale faltante no sistema, veja como alterar o locale para pt_BR.

Ambiente virtual python e dependências de javascript

Em seguida, vamos criar o ambiente virtual python e instalar as dependências do python e do nodejs. O comando abaixo automatiza todo este processo, mas deixamos abaixo a opção manual.

$ cd ~/timtec
$ make install

Se ocorrer algum erro, tente rodar o comando make novamente, pois falhas podem ocorrer devido a problemas com a internet.

Criando ambiente virtual manualmente (opcional, use este ou o make create-production)

Em seguida, vamos criar o ambiente virtual python:

$ virtualenv /home/NOME-DO-SEU-USUARIO-OU-DIRETORIO/env
& source /home/NOME-DO-SEU-USUARIO-OU-DIRETORIO/env/bin/activate

Se você estiver seguindo a documentação, você pode deverá dar o comando da seguinte maneira:

$ virtualenv /home/timtec-production/env
$ source /home/timtec-production/env/bin/activate

Agora vamos instalar as dependências:

cd timtec
make install

Se ocorrer algum erro, tente rodar o comando make novamente, pois falhas podem ocorrer devido a problemas com a internet.

Servidor web e de aplicação

Instale o servidor web (nginx) e o servidor de aplicação (uwsgi):

$ sudo apt-get install -y nginx uwsgi uwsgi-plugin-python

Na pasta timtec/scripts/conf temos exemplo de arquivos de configuração. Copie os mesmos para seus locais e edite-os confore sua necessidade:

$ sudo cp ~/timtec/scripts/conf/timtec-production.ini /etc/uwsgi/apps-available

Crie um link simbólico de apps-available para apps-enable:

$ sudo ln -s /etc/uwsgi/apps-available/timtec-production.ini /etc/uwsgi/apps-enabled/timtec-production.ini

Inicie o serviço do servidor de aplicação:

$ sudo service uwsgi start

Copie os scritps de configuração da instância timtec-production para os sites available do nginx:

$ sudo cp ~/timtec/scripts/conf/nginx-timtec-production /etc/nginx/sites-available/timtec-production

Crie link simbólico do projeto de sites-available para sites-enable:

$ sudo ln -s /etc/nginx/sites-available/timtec-production /etc/nginx/sites-enabled/timtec-production

Remova o arquivo de configuração padrão do nginx para não haver conflito:

$ sudo rm /etc/nginx/sites-enabled/default

Faça um reload do nginx para se certificar que ele está rodando corretamente:

# sudo nginx -s reload

Obs: se o nginx não estiver rodando, execute:

$ sudo service nginx start

Em seguida, edite o arquivo de configuração do nginx para colocar seu domínio.

A instalação não terminou ainda! Precisamos criar o usuário inicial, configurar o domínio do django, o envio de email e a API do youtube.

Proceda a página de Configurações para continuar.