Skip to content

Commit

Permalink
Adds docker-compose.yml file
Browse files Browse the repository at this point in the history
  • Loading branch information
CharlieIGG committed Nov 10, 2019
1 parent b086197 commit 419bcf0
Show file tree
Hide file tree
Showing 3 changed files with 149 additions and 0 deletions.
103 changes: 103 additions & 0 deletions docker-compose.override.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,103 @@
version: "3.7"

volumes:
app_node_modules: # Used to store the app's node modules...

networks:
backend:

services:
# The migration processor container - we'll use this as the base for the rest
# of the app service definitions:
migration: &app
build:
context: .
dockerfile: Dockerfile
target: development
image: icalialabs/testapp:development
entrypoint: /usr/src/bin/dev-entrypoint.sh
volumes:
# Mount the app code into the app containers at the "/usr/src" folder:
- .:/usr/src

# After mounting the app code, this replaces the local 'node_modules'
# folder inside the container with a Docker volume. This is done for
# several reasons:
# - So we can run the frontend app either from the host (i.e. macOS) or
# using containers without having the host & container clobber the npm
# each other's packages, or avoid conflicting versions for macOS / Linux
# - Helps when running on macOS/Windows to speed up the npm install from,
# zero, since a local volume bind on mac/win is noticeably slower than
# a Docker volume - and node module install is very susceptible to
# I/O performance
- app_node_modules:/usr/src/node_modules
networks:
- backend

# Keep the stdin open, so we can attach to our app container's process
# and do things such as byebug, etc:
stdin_open: true

# Enable sending signals (CTRL+C, CTRL+P + CTRL+Q) into the container:
tty: true

# Link to our postgres and redis services, so they can be visible from our
# app service containers:
depends_on:
- postgres
- redis

# The command we want to execute by default when running the container
command: rails db:migrate

# Specify environment variables available for our app containers. We'll
# leave a YML anchor in case we need to override or add more variables if
# needed on each app service:
environment: &app_environment
# We'll set the DATABASE_URL environment variable for the app to connect
# to our postgres container - no need to use a 'config/database.yml' file.
DATABASE_URL: postgres://postgres:3x4mpl3P455w0rd@postgres:5432/

# We'll set the RAILS_ENV and RACK_ENV environment variables to
# 'development', so our app containers will start in 'development' mode
# on this compose project:
RAILS_ENV: development
RACK_ENV: development
RAILS_LOG_TO_STDOUT: "true"
MAILER_HOST: localhost
MAILER_PORT: 3000
LISTEN_USE_POLLING: ${TESTAPP_LISTEN_USE_POLLING:-no}
REDIS_URL: redis://redis:6379/1

web:
<<: *app
command: rails server -p 3000 -b 0.0.0.0
ports:
- ${TESTAPP_WEB_PORT:-3000}:3000
depends_on:
- webpacker
- postgres
- redis

# This container autocompiles, serves and live-reloads Webpack assets
# (including our ReactJS code) for our development environment. This service
# is proxied by the `web` container, so there is no need to publish ports for
# it:
webpacker:
<<: *app
ports:
- ${TESTAPP_WEBPACKER_DEV_SERVER_PORT:-3035}:3035
command: webpack-dev-server
environment:
WEBPACKER_DEV_SERVER_HOST: 0.0.0.0
RAILS_ENV: development

test:
<<: *app
command: rspec
ports:
- ${TESTAPP_WEB_PORT:-3001}:3001
environment:
<<: *app_environment
RAILS_ENV: test
RACK_ENV: test
41 changes: 41 additions & 0 deletions docker-compose.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
version: "3.7"

volumes:
postgres_data:
redis_data:

networks:
backend:

services:
redis:
image: redis:5.0-alpine
ports:
- ${REDIS_PORT:-6379}:6379
volumes:
- redis_data:/data
networks:
- backend
command: redis-server
postgres:
image: postgres:10.6-alpine
volumes:
# We'll store the postgres data in the 'postgres_data' volume we defined:
- postgres_data:/var/lib/postgresql/data
networks:
- backend
environment:
POSTGRES_PASSWORD: 3x4mpl3P455w0rd

# Where are the rest of the app services? (i.e. test, worker, web, etc)
#
# We've separated the app services from the rest of the services to streamline
# the CI/CD pipeline execution. You'll find the app service definitions on the
# `docker-compose.override.yml` file.
#
# You don't have to do anything special to docker-compose or plis to make the
# project work as usual. By default, `docker-compose` will read
# `docker-compose.yml` and `docker-compose.override.yml` files, merging their
# contents before doing any actual work.
#
# See https://docs.docker.com/compose/extends/#understanding-multiple-compose-files
5 changes: 5 additions & 0 deletions example.env
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
# Place here the environment variables you may require for variable
# interpolation on the compose file:
SOME_VARIABLE_NAME=SOME_VALUE
SOME_SECRET_VARIABLE_NAME=A_SECRET_VALUE
PROJECT_NAME_LISTEN_USE_POLLING=no

0 comments on commit 419bcf0

Please sign in to comment.