Production dockerfile

This commit is contained in:
Ryan W
2022-04-24 22:52:31 -07:00
parent b08ef5122f
commit dd7090b107
3 changed files with 51 additions and 0 deletions
+6
View File
@@ -53,6 +53,12 @@ docker compose run --rm web bundle update
docker compose up --build docker compose up --build
``` ```
## Production build
```
docker build -f production.Dockerfile .
```
## Credits/References ## Credits/References
### Rails with Docker ### Rails with Docker
+5
View File
@@ -0,0 +1,5 @@
build:
docker:
web: production.Dockerfile
run:
web: bundle exec puma -C config/puma.rb
+40
View File
@@ -0,0 +1,40 @@
FROM ruby:3.1.2-slim
RUN apt-get update -qq && apt-get install -yq --no-install-recommends \
build-essential \
gnupg2 \
curl \
git \
libpq-dev \
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
ENV LANG=C.UTF-8 \
BUNDLE_JOBS=4 \
BUNDLE_RETRY=3 \
RAILS_ENV=production
RUN gem update --system && gem install bundler
WORKDIR /usr/src/app
COPY Gemfile* ./
RUN bundle config frozen true \
&& bundle config jobs 4 \
&& bundle config deployment true \
&& bundle config without 'development test' \
&& bundle install
COPY . .
# Precompile assets
# SECRET_KEY_BASE or RAILS_MASTER_KEY is required in production, but we don't
# want real secrets in the image or image history. The real secret is passed in
# at run time
ARG SECRET_KEY_BASE=fakekeyforassets
RUN bundle exec rails assets:clobber && bundle exec rails assets:precompile
EXPOSE 3000
CMD ["bundle", "exec", "puma", "-C", "config/puma.rb"]