
Unter der Katze befindet sich eine kleine und einfache Anleitung, die zeigt, wie Docker Compose zum Konfigurieren und Ausführen der Elixir / Phoenix + PostgreSQL-Anwendung verwendet wird.
Vorbereitung
Erstellen Sie ein leeres <app_dir> -Verzeichnis und wechseln Sie dorthin:
mkdir <app_dir> && cd <app_dir>
Erstellen Sie eine
Docker-Datei und füllen Sie sie mit Inhalten.
<app_dir> / Docker-Datei 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
Erstellen Sie
docker-compose.yml und füllen Sie es mit Inhalten.
<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>
Projekterstellung
Wir generieren eine neue Anwendung mit Docker-Compose, wobei <App_Name> der Name der Anwendung ist:
docker-compose run web mix phx.new . --app <app_name>
Wenn Sie Docker unter Linux verwenden, gehören die erstellten Dateien root, da der Container in seinem Namen ausgeführt wird. Um künftige Schwierigkeiten zu vermeiden, müssen Sie den Eigentümer wechseln:
sudo chown -R $USER:$USER .
Datenbankverbindung
Um in den Einstellungen unserer Anwendung eine Verbindung zur Datenbank herzustellen, müssen Sie zwei Dateien ändern:
<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
Nachdem die Einstellungen angepasst wurden, erstellen wir eine Basis für jede Umgebung:
docker-compose run web mix ecto.create
docker-compose run test mix ecto.create
Anwendungsstart
Nun, es bleibt nur unsere Anwendung auszuführen:
docker-compose up -d
Das ist alles. Jetzt ist unsere Anwendung unter
http :
//127.0.0.1-00-00000 verfügbar .

Tests
Und am Ende über das Testen.
Um alle Tests abzuschließen, müssen Sie Folgendes ausführen:
docker-compose run test
So führen Sie einen bestimmten Test durch:
docker-compose run test mix test test/<app_name>_web/controllers/page_controller_test.exs
Das ist alles, alles gut!