2017-04-11 13:49:15 +00:00
|
|
|
#!/bin/bash
|
2017-01-31 18:19:58 +00:00
|
|
|
|
|
|
|
# Copyright 2015 The Kubernetes Authors.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
2017-08-08 18:06:54 +00:00
|
|
|
export NGINX_VERSION=1.13.4
|
2017-01-31 18:19:58 +00:00
|
|
|
export NDK_VERSION=0.3.0
|
2017-06-27 23:36:08 +00:00
|
|
|
export VTS_VERSION=0.1.15
|
2017-01-31 18:19:58 +00:00
|
|
|
export SETMISC_VERSION=0.31
|
2017-05-11 15:44:19 +00:00
|
|
|
export STICKY_SESSIONS_VERSION=08a395c66e42
|
2017-01-31 18:19:58 +00:00
|
|
|
export MORE_HEADERS_VERSION=0.32
|
|
|
|
export NGINX_DIGEST_AUTH=7955af9c77598c697ac292811914ce1e2b3b824c
|
|
|
|
export NGINX_SUBSTITUTIONS=bc58cb11844bc42735bbaef7085ea86ace46d05b
|
|
|
|
|
|
|
|
export BUILD_PATH=/tmp/build
|
|
|
|
|
2017-04-11 13:49:15 +00:00
|
|
|
ARCH=$(uname -p)
|
|
|
|
|
2017-01-31 18:19:58 +00:00
|
|
|
get_src()
|
|
|
|
{
|
|
|
|
hash="$1"
|
|
|
|
url="$2"
|
|
|
|
f=$(basename "$url")
|
|
|
|
|
|
|
|
curl -sSL "$url" -o "$f"
|
|
|
|
echo "$hash $f" | sha256sum -c - || exit 10
|
|
|
|
tar xzf "$f"
|
|
|
|
rm -rf "$f"
|
|
|
|
}
|
|
|
|
|
|
|
|
mkdir "$BUILD_PATH"
|
|
|
|
cd "$BUILD_PATH"
|
|
|
|
|
2017-04-11 13:49:15 +00:00
|
|
|
if [[ ${ARCH} == "ppc64le" ]]; then
|
2017-08-04 02:43:34 +00:00
|
|
|
apt-get update && apt-get install --no-install-recommends -y software-properties-common
|
2017-04-11 13:49:15 +00:00
|
|
|
fi
|
|
|
|
|
2017-01-31 18:19:58 +00:00
|
|
|
# install required packages to build
|
|
|
|
apt-get update && apt-get install --no-install-recommends -y \
|
|
|
|
bash \
|
|
|
|
build-essential \
|
|
|
|
curl ca-certificates \
|
|
|
|
libgeoip1 \
|
|
|
|
libgeoip-dev \
|
|
|
|
patch \
|
|
|
|
libpcre3 \
|
|
|
|
libpcre3-dev \
|
|
|
|
libssl-dev \
|
|
|
|
zlib1g \
|
|
|
|
zlib1g-dev \
|
|
|
|
libaio1 \
|
|
|
|
libaio-dev \
|
|
|
|
openssl \
|
|
|
|
linux-headers-generic || exit 1
|
|
|
|
|
|
|
|
# download, verify and extract the source files
|
2017-08-08 18:06:54 +00:00
|
|
|
get_src de21f3c49ba65c611329d8759a63d72e5fcf719bc6f2a3270e2541348ef1fbba \
|
2017-01-31 18:19:58 +00:00
|
|
|
"http://nginx.org/download/nginx-$NGINX_VERSION.tar.gz"
|
|
|
|
|
|
|
|
get_src 88e05a99a8a7419066f5ae75966fb1efc409bad4522d14986da074554ae61619 \
|
|
|
|
"https://github.com/simpl/ngx_devel_kit/archive/v$NDK_VERSION.tar.gz"
|
|
|
|
|
|
|
|
get_src 97946a68937b50ab8637e1a90a13198fe376d801dc3e7447052e43c28e9ee7de \
|
|
|
|
"https://github.com/openresty/set-misc-nginx-module/archive/v$SETMISC_VERSION.tar.gz"
|
|
|
|
|
2017-06-27 23:36:08 +00:00
|
|
|
get_src 5112a054b1b1edb4c0042a9a840ef45f22abb3c05c68174e28ebf483164fb7e1 \
|
2017-01-31 18:19:58 +00:00
|
|
|
"https://github.com/vozlt/nginx-module-vts/archive/v$VTS_VERSION.tar.gz"
|
|
|
|
|
|
|
|
get_src c6d9dab8ea1fc997031007e2e8f47cced01417e203cd88d53a9fe9f6ae138720 \
|
|
|
|
"https://github.com/openresty/headers-more-nginx-module/archive/v$MORE_HEADERS_VERSION.tar.gz"
|
|
|
|
|
|
|
|
get_src 53e440737ed1aff1f09fae150219a45f16add0c8d6e84546cb7d80f73ebffd90 \
|
|
|
|
"https://bitbucket.org/nginx-goodies/nginx-sticky-module-ng/get/$STICKY_SESSIONS_VERSION.tar.gz"
|
|
|
|
|
|
|
|
get_src 9b1d0075df787338bb607f14925886249bda60b6b3156713923d5d59e99a708b \
|
|
|
|
"https://github.com/atomx/nginx-http-auth-digest/archive/$NGINX_DIGEST_AUTH.tar.gz"
|
|
|
|
|
|
|
|
get_src 8eabbcd5950fdcc718bb0ef9165206c2ed60f67cd9da553d7bc3e6fe4e338461 \
|
|
|
|
"https://github.com/yaoweibin/ngx_http_substitutions_filter_module/archive/$NGINX_SUBSTITUTIONS.tar.gz"
|
|
|
|
|
|
|
|
|
|
|
|
#https://blog.cloudflare.com/optimizing-tls-over-tcp-to-reduce-latency/
|
|
|
|
curl -sSL -o nginx__dynamic_tls_records.patch https://raw.githubusercontent.com/cloudflare/sslconfig/master/patches/nginx__1.11.5_dynamic_tls_records.patch
|
|
|
|
|
|
|
|
# build nginx
|
|
|
|
cd "$BUILD_PATH/nginx-$NGINX_VERSION"
|
|
|
|
|
|
|
|
echo "Applying tls nginx patches..."
|
|
|
|
patch -p1 < $BUILD_PATH/nginx__dynamic_tls_records.patch
|
|
|
|
|
2017-04-17 06:30:34 +00:00
|
|
|
WITH_FLAGS="--with-debug \
|
|
|
|
--with-pcre-jit \
|
|
|
|
--with-http_ssl_module \
|
|
|
|
--with-http_stub_status_module \
|
|
|
|
--with-http_realip_module \
|
|
|
|
--with-http_auth_request_module \
|
|
|
|
--with-http_addition_module \
|
|
|
|
--with-http_dav_module \
|
|
|
|
--with-http_geoip_module \
|
|
|
|
--with-http_gzip_static_module \
|
|
|
|
--with-http_sub_module \
|
|
|
|
--with-http_v2_module \
|
|
|
|
--with-stream \
|
|
|
|
--with-stream_ssl_module \
|
|
|
|
--with-stream_ssl_preread_module \
|
|
|
|
--with-threads"
|
|
|
|
|
|
|
|
if [[ ${ARCH} != "armv7l" || ${ARCH} != "aarch64" ]]; then
|
|
|
|
WITH_FLAGS+=" --with-file-aio"
|
|
|
|
fi
|
|
|
|
|
|
|
|
CC_OPT='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4'
|
|
|
|
|
2017-04-11 13:49:15 +00:00
|
|
|
if [[ ${ARCH} == "x86_64" ]]; then
|
2017-04-17 06:30:34 +00:00
|
|
|
CC_OPT+=' -m64 -mtune=generic'
|
2017-04-11 13:49:15 +00:00
|
|
|
fi
|
|
|
|
|
2017-01-31 18:19:58 +00:00
|
|
|
./configure \
|
|
|
|
--prefix=/usr/share/nginx \
|
|
|
|
--conf-path=/etc/nginx/nginx.conf \
|
|
|
|
--http-log-path=/var/log/nginx/access.log \
|
|
|
|
--error-log-path=/var/log/nginx/error.log \
|
|
|
|
--lock-path=/var/lock/nginx.lock \
|
|
|
|
--pid-path=/run/nginx.pid \
|
|
|
|
--http-client-body-temp-path=/var/lib/nginx/body \
|
|
|
|
--http-fastcgi-temp-path=/var/lib/nginx/fastcgi \
|
|
|
|
--http-proxy-temp-path=/var/lib/nginx/proxy \
|
|
|
|
--http-scgi-temp-path=/var/lib/nginx/scgi \
|
|
|
|
--http-uwsgi-temp-path=/var/lib/nginx/uwsgi \
|
2017-04-17 06:30:34 +00:00
|
|
|
${WITH_FLAGS} \
|
2017-01-31 18:19:58 +00:00
|
|
|
--without-mail_pop3_module \
|
|
|
|
--without-mail_smtp_module \
|
|
|
|
--without-mail_imap_module \
|
|
|
|
--without-http_uwsgi_module \
|
|
|
|
--without-http_scgi_module \
|
2017-04-11 13:49:15 +00:00
|
|
|
--with-cc-opt="${CC_OPT}" \
|
2017-01-31 18:19:58 +00:00
|
|
|
--add-module="$BUILD_PATH/ngx_devel_kit-$NDK_VERSION" \
|
|
|
|
--add-module="$BUILD_PATH/set-misc-nginx-module-$SETMISC_VERSION" \
|
|
|
|
--add-module="$BUILD_PATH/nginx-module-vts-$VTS_VERSION" \
|
|
|
|
--add-module="$BUILD_PATH/headers-more-nginx-module-$MORE_HEADERS_VERSION" \
|
|
|
|
--add-module="$BUILD_PATH/nginx-goodies-nginx-sticky-module-ng-$STICKY_SESSIONS_VERSION" \
|
|
|
|
--add-module="$BUILD_PATH/nginx-http-auth-digest-$NGINX_DIGEST_AUTH" \
|
|
|
|
--add-module="$BUILD_PATH/ngx_http_substitutions_filter_module-$NGINX_SUBSTITUTIONS" \
|
|
|
|
&& make || exit 1 \
|
|
|
|
&& make install || exit 1
|
|
|
|
|
|
|
|
echo "Cleaning..."
|
|
|
|
|
|
|
|
cd /
|
|
|
|
|
|
|
|
apt-mark unmarkauto \
|
|
|
|
bash \
|
|
|
|
curl ca-certificates \
|
|
|
|
libgeoip1 \
|
|
|
|
libpcre3 \
|
|
|
|
zlib1g \
|
|
|
|
libaio1 \
|
|
|
|
xz-utils \
|
|
|
|
geoip-bin \
|
|
|
|
openssl
|
|
|
|
|
|
|
|
apt-get remove -y --purge \
|
|
|
|
build-essential \
|
|
|
|
gcc-5 \
|
|
|
|
cpp-5 \
|
|
|
|
libgeoip-dev \
|
|
|
|
libpcre3-dev \
|
|
|
|
libssl-dev \
|
|
|
|
zlib1g-dev \
|
|
|
|
libaio-dev \
|
|
|
|
linux-libc-dev \
|
|
|
|
perl-modules-5.22 \
|
|
|
|
linux-headers-generic
|
|
|
|
|
|
|
|
apt-get autoremove -y
|
|
|
|
|
|
|
|
mkdir -p /var/lib/nginx/body /usr/share/nginx/html
|
|
|
|
|
|
|
|
mv /usr/share/nginx/sbin/nginx /usr/sbin
|
|
|
|
|
|
|
|
rm -rf "$BUILD_PATH"
|
|
|
|
rm -Rf /usr/share/man /usr/share/doc
|
|
|
|
rm -rf /tmp/* /var/tmp/*
|
|
|
|
rm -rf /var/lib/apt/lists/*
|
|
|
|
rm -rf /var/cache/apt/archives/*
|
|
|
|
|
|
|
|
# Download of GeoIP databases
|
|
|
|
curl -sSL -o /etc/nginx/GeoIP.dat.gz http://geolite.maxmind.com/download/geoip/database/GeoLiteCountry/GeoIP.dat.gz \
|
|
|
|
&& curl -sSL -o /etc/nginx/GeoLiteCity.dat.gz http://geolite.maxmind.com/download/geoip/database/GeoLiteCity.dat.gz \
|
|
|
|
&& gunzip /etc/nginx/GeoIP.dat.gz \
|
|
|
|
&& gunzip /etc/nginx/GeoLiteCity.dat.gz
|