forked from heroku/heroku-buildpack-nginx
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathDockerfile
103 lines (92 loc) · 3.46 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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
# Emulate cedar-16 stack: https://devcenter.heroku.com/articles/stack
FROM ubuntu:xenial
# Install prerequisites (these are available on Heroku)
RUN apt-get update
RUN apt-get install -y wget \
curl \
git \
build-essential \
autoconf \
libtool \
libpcre3 \
libpcre3-dev \
libssl-dev
# To get `erb` like on Heroku
RUN apt-get install -y ruby-full
ENV LAST_UPDATED 20170801
# https://devcenter.heroku.com/articles/buildpack-api#stacks
ENV STACK heroku-16
RUN mkdir /var/buildpack_cache
RUN mkdir /var/buildpack
COPY dummy_app /var/dummy_app
COPY config /var/buildpack/config
COPY buildpack_env /var/buildpack_env
# # Download MaxMind GeoLite2 databases
# RUN mkdir -p /usr/share/GeoIP/ &&\
# wget http://geolite.maxmind.com/download/geoip/database/GeoLite2-City.mmdb.gz &&\
# gunzip GeoLite2-City.mmdb.gz &&\
# mv GeoLite2-City.mmdb /usr/share/GeoIP/ &&\
# wget http://geolite.maxmind.com/download/geoip/database/GeoLite2-Country.mmdb.gz &&\
# gunzip GeoLite2-Country.mmdb.gz &&\
# mv GeoLite2-Country.mmdb /usr/share/GeoIP/
#
# # Install C library for reading MaxMind DB files
# # Resource: https://github.com/maxmind/libmaxminddb
# RUN git clone --recursive https://github.com/maxmind/libmaxminddb.git &&\
# cd libmaxminddb &&\
# ./bootstrap &&\
# ./configure &&\
# make &&\
# make check &&\
# make install &&\
# echo /usr/local/lib >> /etc/ld.so.conf.d/local.conf &&\
# ldconfig
#
# # Download Nginx and the Nginx geoip2 module
# RUN curl http://nginx.org/download/nginx-$NGINX_VERSION.tar.gz | tar xz &&\
# git clone https://github.com/leev/ngx_http_geoip2_module.git
#
# WORKDIR /nginx-$NGINX_VERSION
#
# # Compile Nginx
# RUN ./configure \
# --prefix=/etc/nginx \
# --sbin-path=/usr/sbin/nginx \
# --conf-path=/etc/nginx/nginx.conf \
# --error-log-path=/var/log/nginx/error.log \
# --http-log-path=/var/log/nginx/access.log \
# --pid-path=/var/run/nginx.pid \
# --lock-path=/var/run/nginx.lock \
# --http-client-body-temp-path=/var/cache/nginx/client_temp \
# --http-proxy-temp-path=/var/cache/nginx/proxy_temp \
# --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp \
# --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp \
# --http-scgi-temp-path=/var/cache/nginx/scgi_temp \
# --user=nginx \
# --group=nginx \
# --with-http_ssl_module \
# --with-http_realip_module \
# --with-http_addition_module \
# --with-http_sub_module \
# --with-http_dav_module \
# --with-http_gunzip_module \
# --with-http_gzip_static_module \
# --with-http_random_index_module \
# --with-http_secure_link_module \
# --with-http_stub_status_module \
# --with-http_auth_request_module \
# --with-threads \
# --with-stream \
# --with-stream_ssl_module \
# --with-file-aio \
# --with-cc-opt='-g -O2 -fstack-protector-strong -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2' \
# --with-ld-opt='-Wl,-z,relro -Wl,--as-needed' \
# --with-ipv6 \
# --add-module=/ngx_http_geoip2_module &&\
# make &&\
# make install
# COPY config/conf.d /etc/nginx/conf.d
# COPY config/includes /etc/nginx/includes
# COPY config/nginx.conf /etc/nginx/nginx.conf
# CMD "/var/dummy_app/bin/start-nginx bundle exec puma -C puma.rb -b unix:///tmp/nginx.socket"
CMD "nginx -g 'daemon off;'"