forked from tellapart/aurproxy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Dockerfile
152 lines (130 loc) · 5.39 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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
# Newer python base images may break gevent.
# See https://github.com/docker-library/python/issues/29#issuecomment-70727289
FROM --platform=linux/amd64 ubuntu:xenial
MAINTAINER [email protected]
######
# System prerequisite installation
######
# Update apt repository
# Install python prerequisites
# Install libpcap
# Aurora/Mesos requirements (see AURORA-1487)
ENV AZ_REPO xenial
ENV DEV_PKGS build-essential curl libpcre3-dev zlib1g-dev libssl-dev libxml2-dev libgeoip-dev
RUN apt-get update \
&& apt-get install -y git python2.7 apt-transport-https $DEV_PKGS python-pip python-dev libpcap-dev libcurl4-nss-dev libapr1-dev gcc \
libsvn-dev openssl libssl1.0.0 libxml2 libxslt1.1 libgeoip1 libpcre3 zlib1g \
&& echo "deb [arch=amd64] https://packages.microsoft.com/repos/azure-cli/ $AZ_REPO main" | tee /etc/apt/sources.list.d/azure-cli.list \
&& curl -L https://packages.microsoft.com/keys/microsoft.asc | apt-key add - \
&& apt-get update && apt-get install -y azure-cli \
&& apt-get clean \
&& rm -rf /var/lib/apt/lists/*
# Install go
RUN echo 'e40c36ae71756198478624ed1bb4ce17597b3c19d243f3f0899bb5740d56212a go1.6.2.linux-amd64.tar.gz' >go.sha256sum \
&& curl -s -L -o go1.6.2.linux-amd64.tar.gz https://storage.googleapis.com/golang/go1.6.2.linux-amd64.tar.gz \
&& sha256sum -c go.sha256sum \
&& tar -C /usr/local -xzf go1.6.2.linux-amd64.tar.gz
# Install gor
ENV PATH=$PATH:/usr/local/go/bin
ENV GOPATH=/opt/go
RUN mkdir -p $GOPATH \
&& go get github.com/buger/gor \
&& cd $GOPATH/src/github.com/buger/gor \
&& go build
# Install nginx
ENV NGX_DEV_KIT_VER 0.2.19
ENV NGX_VER 1.9.0
ENV NGX_MD5 487c26cf0470d8869c41a73621847268
ENV NGX_STATSD_VER b756a12abf110b9e36399ab7ede346d4bb86d691
ENV NGX_HEADERS_MORE_VER 0.26
ENV NGX_ECHO_VER 0.57
RUN mkdir -p /tmp/build && cd /tmp/build \
&& curl -s -L -o ngx_devel.tar.gz \
https://github.com/simpl/ngx_devel_kit/archive/v$NGX_DEV_KIT_VER.tar.gz \
&& curl -s -L -o ngx.tar.gz \
http://nginx.org/download/nginx-$NGX_VER.tar.gz \
&& curl -s -L -o ngx_statsd.tar.gz \
https://github.com/zebrafishlabs/nginx-statsd/archive/$NGX_STATSD_VER.tar.gz \
&& curl -s -L -o ngx_headers_more.tar.gz \
https://github.com/openresty/headers-more-nginx-module/archive/v$NGX_HEADERS_MORE_VER.tar.gz \
&& curl -s -L -o ngx_echo.tar.gz \
https://github.com/openresty/echo-nginx-module/archive/v$NGX_ECHO_VER.tar.gz \
&& echo "$NGX_MD5 ngx.tar.gz" | md5sum -c - || (echo "MD5 for ngx.tar.gz didn't match expected!" && exit 1) \
&& tar -xvf ngx_devel.tar.gz \
&& tar -xvf ngx.tar.gz \
&& tar -xvf ngx_statsd.tar.gz \
&& tar -xvf ngx_headers_more.tar.gz \
&& tar -xvf ngx_echo.tar.gz \
&& cd /tmp/build/nginx-$NGX_VER \
&& ./configure --prefix=/usr \
--conf-path=/etc/nginx/nginx.conf \
--error-log-path=/var/log/nginx/error.log \
--http-client-body-temp-path=/var/lib/nginx/body \
--http-fastcgi-temp-path=/var/lib/nginx/fastcgi \
--http-log-path=/var/log/nginx/access.log \
--http-proxy-temp-path=/var/lib/nginx/proxy \
--http-scgi-temp-path=/var/lib/nginx/scgi \
--http-uwsgi-temp-path=/var/lib/nginx/uwsgi \
--lock-path=/var/lock/nginx.lock \
--pid-path=/var/run/nginx.pid \
--with-debug \
--with-http_addition_module \
--with-http_dav_module \
--with-http_geoip_module \
--with-http_gzip_static_module \
--with-http_realip_module \
--with-http_stub_status_module \
--with-http_ssl_module \
--with-http_sub_module \
--with-stream \
--with-ipv6 \
--with-sha1=/usr/include/openssl \
--with-md5=/usr/include/openssl \
--add-module=/tmp/build/nginx-statsd-$NGX_STATSD_VER/ \
--add-module=/tmp/build/headers-more-nginx-module-$NGX_HEADERS_MORE_VER \
--add-module=/tmp/build/echo-nginx-module-$NGX_ECHO_VER \
&& make -j4 \
&& make install \
&& cd / \
&& rm -rf /tmp/build \
&& apt-get purge -y $DEV_PKGS \
&& apt-get autoremove -y \
&& apt-get purge -y \
&& apt-get clean \
&& rm -rf /var/lib/apt/lists/*
RUN mkdir -p /etc/nginx/sites-enabled \
&& mkdir -p /etc/nginx/sites-available \
&& mkdir -p /var/lib/nginx
######
# System prerequisite configuration
######
# Set up run directory for pids
RUN mkdir -p /var/run
# Remove default nginx config
RUN rm /etc/nginx/nginx.conf
# Symlink aurproxy nginx config
RUN mkdir -p /etc/aurproxy/nginx
RUN ln -sf /etc/aurproxy/nginx/nginx.conf /etc/nginx
# Create dynamic gor config location
RUN mkdir -p /etc/aurproxy/gor
######
# Application prerequisite installation
######
# Set up application sandbox
# (Gets mounted by aurora in production)
RUN mkdir -p /mnt/mesos/sandbox/sandbox
# Set up application directory
RUN mkdir -p /opt/aurproxy/
# Add application requirements
ADD ./requirements.txt /opt/aurproxy/requirements.txt
# Install application requirements
RUN pip2 install --upgrade pip && pip2 install -r /opt/aurproxy/requirements.txt
######
# Application setup
######
ADD ./tellapart/__init__.py /opt/aurproxy/tellapart/__init__.py
ADD ./tellapart/aurproxy /opt/aurproxy/tellapart/aurproxy
ADD ./templates /opt/aurproxy/tellapart/aurproxy/templates
# Not intended to be run
# Command will come from aurproxy.aur
CMD ["echo done"]