Desenvolvimento de aplicativos no Elixir / Phoenix com Docker



Abaixo do gato, há um guia pequeno e simples que mostra como usar o Docker Compose para configurar e iniciar o aplicativo Elixir / Phoenix + PostgreSQL.

Preparação


Crie um diretório <app_dir> vazio e acesse:

mkdir <app_dir> && cd <app_dir> 

Crie um Dockerfile e preencha-o com conteúdo.

<app_dir> / dockerfile
 FROM elixir:latest RUN apt-get update -qq && apt-get install -y libpq-dev && apt-get install -y build-essential inotify-tools erlang-dev erlang-parsetools apt-transport-https ca-certificates && apt-get update && curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add - && echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list && apt-get update && apt-get install --no-install-recommends yarn RUN mix local.hex --force && mix local.rebar --force RUN mix archive.install hex phx_new 1.4.0 --force RUN curl -sL https://deb.nodesource.com/setup_11.x | bash - && apt-get install -y nodejs WORKDIR /home/app 


Crie docker-compose.yml e preencha-o com conteúdo.

<app_dir> /docker-compose.yml
 version: '3' services: web: build: . command: mix phx.server volumes: - .:/home/app ports: - "4000:4000" links: - db depends_on: - db test: image: <app_dir>_web command: mix test environment: MIX_ENV: test PORT: 4001 volumes: - .:/home/app db: image: postgres:latest ports: - '5432:5432' environment: POSTGRES_USER: <db_user> POSTGRES_PASSWORD: <db_user_password> 



Criação de projeto


Geramos um novo aplicativo usando o docker-compose, em que <app_name> é o nome do aplicativo:

 docker-compose run web mix phx.new . --app <app_name> 

Se você usa o Docker no Linux, os arquivos criados pertencem à raiz, pois o contêiner é executado em seu nome. Para evitar dificuldades no futuro, você precisa alterar o proprietário:

 sudo chown -R $USER:$USER . 

Conexão com o Banco de Dados


Para se conectar ao banco de dados nas configurações de nosso aplicativo, você precisa alterar dois arquivos:

<app_dir> /config/dev.exs
 # Configure your database config :<app_name>, <App_name>.Repo, username: <db_user>, password: <db_user_password>, database: <app_name>_dev, hostname: "db", pool_size: 10 


<app_dir> /config/test.exs
 # Configure your database config :<app_name>, <App_name>.Repo, username: <db_user>, password: <db_user_password>, database: <app_name>_test, hostname: "db", pool_size: 10 


Depois que as configurações são ajustadas, criamos uma base para cada ambiente:

 docker-compose run web mix ecto.create 

 docker-compose run test mix ecto.create 

Lançamento do aplicativo


Bem, resta apenas executar a nossa aplicação:

 docker-compose up -d 

Isso é tudo. Agora, nosso aplicativo está disponível em http : //127.0.0.1-00-00000 .



Testes


E no final sobre testes.

Para concluir todos os testes, você precisa executar:

 docker-compose run test 

Para executar um teste específico:

 docker-compose run test mix test test/<app_name>_web/controllers/page_controller_test.exs 

Isso é tudo, tudo de bom!

Source: https://habr.com/ru/post/pt439718/


All Articles