Suche…


Einführung

Dieses Tutorial beginnt mit der Installation von Docker und einer Rails-App

Docker und Docker komponieren

Zunächst müssen wir unsere Dockerfile erstellen. Ein gutes Beispiel ist in diesem Blog von Nick Janetakis zu finden.

Dieser Code enthält das Skript, das zum Zeitpunkt des Starts auf unserer Docker-Maschine ausgeführt wird. Aus diesem Grund installieren wir alle erforderlichen Bibliotheken und enden mit dem Start von Puma (RoR dev-Server).

# Use the barebones version of Ruby 2.3.
FROM ruby:2.3.0-slim

# Optionally set a maintainer name to let people know who made this image.
MAINTAINER Nick Janetakis <[email protected]>

# Install dependencies:
# - build-essential: To ensure certain gems can be compiled
# - nodejs: Compile assets
# - libpq-dev: Communicate with postgres through the postgres gem
RUN apt-get update && apt-get install -qq -y --no-install-recommends \
      build-essential nodejs libpq-dev git


# Set an environment variable to store where the app is installed to inside
# of the Docker image. The name matches the project name out of convention only.
ENV INSTALL_PATH /mh-backend
RUN mkdir -p $INSTALL_PATH

# This sets the context of where commands will be running in and is documented
# on Docker's website extensively.
WORKDIR $INSTALL_PATH

# We want binstubs to be available so we can directly call sidekiq and
# potentially other binaries as command overrides without depending on
# bundle exec.
COPY Gemfile* $INSTALL_PATH/

ENV BUNDLE_GEMFILE $INSTALL_PATH/Gemfile
ENV BUNDLE_JOBS 2 
ENV BUNDLE_PATH /gembox

RUN bundle install

# Copy in the application code from your work station at the current directory
# over to the working directory.
COPY . .

# Ensure the static assets are exposed to a volume so that nginx can read
# in these values later.
VOLUME ["$INSTALL_PATH/public"]

ENV RAILS_LOG_TO_STDOUT true


# The default command that gets run will be to start the Puma server.
CMD bundle exec puma -C config/puma.rb

Außerdem werden wir docker-compose.yml . docker-compose.yml erstellen wir docker-compose.yml . Die Erklärung dieser Datei wird eher ein Docker-Compose-Tutorial als eine Integration mit Rails sein. Ich werde hier nicht weiter darauf eingehen.

version: '2'

services:
  backend:
    links:
      - #whatever you need to link like db
    build: .
    command: ./scripts/start.sh
    ports:
      - '3000:3000'
    volumes:
      - .:/backend
    volumes_from:
      - gembox
    env_file:
      - .dev-docker.env
    stdin_open: true
    tty: true

Nur mit diesen beiden Dateien haben Sie genug, um docker-compose up auszuführen und Ihr Docker zu aktivieren



Modified text is an extract of the original Stack Overflow Documentation
Lizenziert unter CC BY-SA 3.0
Nicht angeschlossen an Stack Overflow