-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathDockerfile
78 lines (62 loc) · 2.57 KB
/
Dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
FROM phusion/passenger-full:2.1.0
LABEL maintainer="[email protected]"
# Set correct environment variables.
ENV HOME /home/app
ENV LC_ALL en_US.UTF-8
ENV LANG en_US.UTF-8
# Allow app user to read /etc/container_environment
RUN usermod -a -G docker_env app
# Use baseimage-docker's init process.
CMD ["/sbin/my_init"]
# Use Ruby 2.6.9
RUN bash -lc 'rvm --default use ruby-2.6.9'
# Update installed APT packages
RUN apt-get update && apt-get upgrade -y -o Dpkg::Options::="--force-confold" && \
apt-get install ntp wget nano tmux tzdata percona-toolkit imagemagick shared-mime-info -y && \
apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
# Enable Passenger and Nginx and remove the default site
# Preserve env variables for nginx
RUN rm -f /etc/service/nginx/down && \
rm /etc/nginx/sites-enabled/default
COPY vendor/docker/webapp.conf /etc/nginx/sites-enabled/webapp.conf
COPY vendor/docker/00_app_env.conf /etc/nginx/conf.d/00_app_env.conf
# Use Amazon NTP servers
COPY vendor/docker/ntp.conf /etc/ntp.conf
# Add Runit script for shoryuken workers
WORKDIR /home/app/webapp
RUN mkdir /etc/service/shoryuken
COPY vendor/docker/shoryuken.sh /etc/service/shoryuken/run
# Install Passenger monitor for Datadog
# RUN wget https://github.com/Sjeanpierre/passenger-datadog-monitor/releases/download/v1.00/passenger-datadog-monitor && \
# mv passenger-datadog-monitor /usr/local/bin && \
# chmod +x /usr/local/bin/passenger-datadog-monitor && \
# mkdir /etc/service/passenger-datadog
# COPY vendor/docker/passenger-datadog.sh /etc/service/passenger-datadog/run
# RUN chmod +x /etc/service/passenger-datadog/run
# Install Ruby gems
COPY Gemfile* /home/app/webapp/
WORKDIR /home/app/webapp
RUN mkdir -p vendor/bundle && \
chown -R app:app . && \
chmod -R 755 . && \
gem update --system && \
gem install bundler:2.3.10 && \
/sbin/setuser app bundle config set --local path 'vendor/bundle' && \
/sbin/setuser app bundle install
# Copy webapp folder
COPY . /home/app/webapp/
RUN mkdir -p tmp/pids && \
mkdir -p tmp/storage && \
chown -R app:app /home/app/webapp && \
chmod -R 755 /home/app/webapp
# enable SSH
RUN rm -f /etc/service/sshd/down && \
/etc/my_init.d/00_regen_ssh_host_keys.sh
# Run additional scripts during container startup (i.e. not at build time)
RUN mkdir -p /etc/my_init.d
# install custom ssh key during startup
COPY vendor/docker/10_ssh.sh /etc/my_init.d/10_ssh.sh
# COPY vendor/docker/80_flush_cache.sh /etc/my_init.d/80_flush_cache.sh
COPY vendor/docker/90_migrate.sh /etc/my_init.d/90_migrate.sh
# Expose web
EXPOSE 80