diff --git a/5.4/Dockerfile b/5.4/Dockerfile index eba8265b..a3b893b7 100644 --- a/5.4/Dockerfile +++ b/5.4/Dockerfile @@ -1,20 +1,30 @@ -FROM buildpack-deps:jessie +FROM debian:jessie -RUN apt-get update && apt-get install -y curl && rm -r /var/lib/apt/lists/* +# persistent / runtime deps +RUN apt-get update && apt-get install -y curl libxml2 --no-install-recommends && rm -r /var/lib/apt/lists/* -#### -#### +#### +#### RUN gpg --keyserver pgp.mit.edu --recv-keys F38252826ACD957EF380D39F2F7956BC5DA04B5D ENV PHP_VERSION 5.4.34 -RUN set -x \ - && curl -SLO http://launchpadlibrarian.net/140087283/libbison-dev_2.7.1.dfsg-1_amd64.deb \ - && curl -SLO http://launchpadlibrarian.net/140087282/bison_2.7.1.dfsg-1_amd64.deb \ - && dpkg -i libbison-dev_2.7.1.dfsg-1_amd64.deb \ - && dpkg -i bison_2.7.1.dfsg-1_amd64.deb \ - && rm *.deb \ +RUN buildDeps=" \ + $PHP_EXTRA_BUILD_DEPS \ + build-essential \ + bzip2 \ + file \ + libcurl4-openssl-dev \ + libpng12-dev \ + libreadline6-dev \ + libssl-dev \ + libxml2-dev \ + m4 \ + pkg-config \ + "; \ + set -x \ + && apt-get update && apt-get install -y $buildDeps --no-install-recommends && rm -rf /var/lib/apt/lists/* \ && curl -SL "http://php.net/get/php-$PHP_VERSION.tar.bz2/from/this/mirror" -o php.tar.bz2 \ && curl -SL "http://php.net/get/php-$PHP_VERSION.tar.bz2.asc/from/this/mirror" -o php.tar.bz2.asc \ && gpg --verify php.tar.bz2.asc \ @@ -23,17 +33,21 @@ RUN set -x \ && rm php.tar.bz2* \ && cd /usr/src/php \ && ./configure --disable-cgi \ - $(command -v apxs2 > /dev/null 2>&1 && echo '--with-apxs2' || true) \ + $PHP_EXTRA_CONFIGURE_ARGS \ --with-curl \ --with-gd \ --with-mysql \ --with-mysqli \ --with-openssl \ --with-pdo-mysql \ + --with-readline \ --with-zlib \ && make -j"$(nproc)" \ && make install \ - && dpkg -r bison libbison-dev \ + && { find /usr/local/bin /usr/local/sbin -type f -executable -exec strip --strip-all '{}' + || true; } \ + && apt-get purge -y --auto-remove $buildDeps \ && rm -r /usr/src/php +#### CMD ["php", "-a"] +#### diff --git a/5.4/apache/Dockerfile b/5.4/apache/Dockerfile index 14330d6e..4c50e6a8 100644 --- a/5.4/apache/Dockerfile +++ b/5.4/apache/Dockerfile @@ -1,9 +1,10 @@ -FROM buildpack-deps:jessie +FROM debian:jessie -RUN apt-get update && apt-get install -y curl && rm -r /var/lib/apt/lists/* +# persistent / runtime deps +RUN apt-get update && apt-get install -y curl libxml2 --no-install-recommends && rm -r /var/lib/apt/lists/* -#### -RUN apt-get update && apt-get install -y apache2-bin apache2-dev apache2.2-common --no-install-recommends && rm -rf /var/lib/apt/lists/* +#### +RUN apt-get update && apt-get install -y apache2-bin apache2.2-common --no-install-recommends && rm -rf /var/lib/apt/lists/* RUN rm -rf /var/www/html && mkdir -p /var/lock/apache2 /var/run/apache2 /var/log/apache2 /var/www/html && chown -R www-data:www-data /var/lock/apache2 /var/run/apache2 /var/log/apache2 /var/www/html @@ -12,18 +13,31 @@ RUN a2dismod mpm_event && a2enmod mpm_prefork RUN mv /etc/apache2/apache2.conf /etc/apache2/apache2.conf.dist COPY apache2.conf /etc/apache2/apache2.conf -#### +# it'd be nice if we could not COPY apache2.conf until the end of the Dockerfile, but its contents are checked by PHP during compilation + +ENV PHP_EXTRA_BUILD_DEPS apache2-dev +ENV PHP_EXTRA_CONFIGURE_ARGS --with-apxs2 +#### RUN gpg --keyserver pgp.mit.edu --recv-keys F38252826ACD957EF380D39F2F7956BC5DA04B5D ENV PHP_VERSION 5.4.34 -RUN set -x \ - && curl -SLO http://launchpadlibrarian.net/140087283/libbison-dev_2.7.1.dfsg-1_amd64.deb \ - && curl -SLO http://launchpadlibrarian.net/140087282/bison_2.7.1.dfsg-1_amd64.deb \ - && dpkg -i libbison-dev_2.7.1.dfsg-1_amd64.deb \ - && dpkg -i bison_2.7.1.dfsg-1_amd64.deb \ - && rm *.deb \ +RUN buildDeps=" \ + $PHP_EXTRA_BUILD_DEPS \ + build-essential \ + bzip2 \ + file \ + libcurl4-openssl-dev \ + libpng12-dev \ + libreadline6-dev \ + libssl-dev \ + libxml2-dev \ + m4 \ + pkg-config \ + "; \ + set -x \ + && apt-get update && apt-get install -y $buildDeps --no-install-recommends && rm -rf /var/lib/apt/lists/* \ && curl -SL "http://php.net/get/php-$PHP_VERSION.tar.bz2/from/this/mirror" -o php.tar.bz2 \ && curl -SL "http://php.net/get/php-$PHP_VERSION.tar.bz2.asc/from/this/mirror" -o php.tar.bz2.asc \ && gpg --verify php.tar.bz2.asc \ @@ -32,20 +46,24 @@ RUN set -x \ && rm php.tar.bz2* \ && cd /usr/src/php \ && ./configure --disable-cgi \ - $(command -v apxs2 > /dev/null 2>&1 && echo '--with-apxs2' || true) \ + $PHP_EXTRA_CONFIGURE_ARGS \ --with-curl \ --with-gd \ --with-mysql \ --with-mysqli \ --with-openssl \ --with-pdo-mysql \ + --with-readline \ --with-zlib \ && make -j"$(nproc)" \ && make install \ - && dpkg -r bison libbison-dev \ + && { find /usr/local/bin /usr/local/sbin -type f -executable -exec strip --strip-all '{}' + || true; } \ + && apt-get purge -y --auto-remove $buildDeps \ && rm -r /usr/src/php +#### WORKDIR /var/www/html EXPOSE 80 CMD ["apache2", "-DFOREGROUND"] +#### diff --git a/5.5/Dockerfile b/5.5/Dockerfile index 441c3687..46374d36 100644 --- a/5.5/Dockerfile +++ b/5.5/Dockerfile @@ -1,20 +1,30 @@ -FROM buildpack-deps:jessie +FROM debian:jessie -RUN apt-get update && apt-get install -y curl && rm -r /var/lib/apt/lists/* +# persistent / runtime deps +RUN apt-get update && apt-get install -y curl libxml2 --no-install-recommends && rm -r /var/lib/apt/lists/* -#### -#### +#### +#### RUN gpg --keyserver pgp.mit.edu --recv-keys 0BD78B5F97500D450838F95DFE857D9A90D90EC1 0B96609E270F565C13292B24C13C70B87267B52D ENV PHP_VERSION 5.5.18 -RUN set -x \ - && curl -SLO http://launchpadlibrarian.net/140087283/libbison-dev_2.7.1.dfsg-1_amd64.deb \ - && curl -SLO http://launchpadlibrarian.net/140087282/bison_2.7.1.dfsg-1_amd64.deb \ - && dpkg -i libbison-dev_2.7.1.dfsg-1_amd64.deb \ - && dpkg -i bison_2.7.1.dfsg-1_amd64.deb \ - && rm *.deb \ +RUN buildDeps=" \ + $PHP_EXTRA_BUILD_DEPS \ + build-essential \ + bzip2 \ + file \ + libcurl4-openssl-dev \ + libpng12-dev \ + libreadline6-dev \ + libssl-dev \ + libxml2-dev \ + m4 \ + pkg-config \ + "; \ + set -x \ + && apt-get update && apt-get install -y $buildDeps --no-install-recommends && rm -rf /var/lib/apt/lists/* \ && curl -SL "http://php.net/get/php-$PHP_VERSION.tar.bz2/from/this/mirror" -o php.tar.bz2 \ && curl -SL "http://php.net/get/php-$PHP_VERSION.tar.bz2.asc/from/this/mirror" -o php.tar.bz2.asc \ && gpg --verify php.tar.bz2.asc \ @@ -23,17 +33,21 @@ RUN set -x \ && rm php.tar.bz2* \ && cd /usr/src/php \ && ./configure --disable-cgi \ - $(command -v apxs2 > /dev/null 2>&1 && echo '--with-apxs2' || true) \ + $PHP_EXTRA_CONFIGURE_ARGS \ --with-curl \ --with-gd \ --with-mysql \ --with-mysqli \ --with-openssl \ --with-pdo-mysql \ + --with-readline \ --with-zlib \ && make -j"$(nproc)" \ && make install \ - && dpkg -r bison libbison-dev \ + && { find /usr/local/bin /usr/local/sbin -type f -executable -exec strip --strip-all '{}' + || true; } \ + && apt-get purge -y --auto-remove $buildDeps \ && rm -r /usr/src/php +#### CMD ["php", "-a"] +#### diff --git a/5.5/apache/Dockerfile b/5.5/apache/Dockerfile index f394c505..9246e885 100644 --- a/5.5/apache/Dockerfile +++ b/5.5/apache/Dockerfile @@ -1,9 +1,10 @@ -FROM buildpack-deps:jessie +FROM debian:jessie -RUN apt-get update && apt-get install -y curl && rm -r /var/lib/apt/lists/* +# persistent / runtime deps +RUN apt-get update && apt-get install -y curl libxml2 --no-install-recommends && rm -r /var/lib/apt/lists/* -#### -RUN apt-get update && apt-get install -y apache2-bin apache2-dev apache2.2-common --no-install-recommends && rm -rf /var/lib/apt/lists/* +#### +RUN apt-get update && apt-get install -y apache2-bin apache2.2-common --no-install-recommends && rm -rf /var/lib/apt/lists/* RUN rm -rf /var/www/html && mkdir -p /var/lock/apache2 /var/run/apache2 /var/log/apache2 /var/www/html && chown -R www-data:www-data /var/lock/apache2 /var/run/apache2 /var/log/apache2 /var/www/html @@ -12,18 +13,31 @@ RUN a2dismod mpm_event && a2enmod mpm_prefork RUN mv /etc/apache2/apache2.conf /etc/apache2/apache2.conf.dist COPY apache2.conf /etc/apache2/apache2.conf -#### +# it'd be nice if we could not COPY apache2.conf until the end of the Dockerfile, but its contents are checked by PHP during compilation + +ENV PHP_EXTRA_BUILD_DEPS apache2-dev +ENV PHP_EXTRA_CONFIGURE_ARGS --with-apxs2 +#### RUN gpg --keyserver pgp.mit.edu --recv-keys 0BD78B5F97500D450838F95DFE857D9A90D90EC1 0B96609E270F565C13292B24C13C70B87267B52D ENV PHP_VERSION 5.5.18 -RUN set -x \ - && curl -SLO http://launchpadlibrarian.net/140087283/libbison-dev_2.7.1.dfsg-1_amd64.deb \ - && curl -SLO http://launchpadlibrarian.net/140087282/bison_2.7.1.dfsg-1_amd64.deb \ - && dpkg -i libbison-dev_2.7.1.dfsg-1_amd64.deb \ - && dpkg -i bison_2.7.1.dfsg-1_amd64.deb \ - && rm *.deb \ +RUN buildDeps=" \ + $PHP_EXTRA_BUILD_DEPS \ + build-essential \ + bzip2 \ + file \ + libcurl4-openssl-dev \ + libpng12-dev \ + libreadline6-dev \ + libssl-dev \ + libxml2-dev \ + m4 \ + pkg-config \ + "; \ + set -x \ + && apt-get update && apt-get install -y $buildDeps --no-install-recommends && rm -rf /var/lib/apt/lists/* \ && curl -SL "http://php.net/get/php-$PHP_VERSION.tar.bz2/from/this/mirror" -o php.tar.bz2 \ && curl -SL "http://php.net/get/php-$PHP_VERSION.tar.bz2.asc/from/this/mirror" -o php.tar.bz2.asc \ && gpg --verify php.tar.bz2.asc \ @@ -32,20 +46,24 @@ RUN set -x \ && rm php.tar.bz2* \ && cd /usr/src/php \ && ./configure --disable-cgi \ - $(command -v apxs2 > /dev/null 2>&1 && echo '--with-apxs2' || true) \ + $PHP_EXTRA_CONFIGURE_ARGS \ --with-curl \ --with-gd \ --with-mysql \ --with-mysqli \ --with-openssl \ --with-pdo-mysql \ + --with-readline \ --with-zlib \ && make -j"$(nproc)" \ && make install \ - && dpkg -r bison libbison-dev \ + && { find /usr/local/bin /usr/local/sbin -type f -executable -exec strip --strip-all '{}' + || true; } \ + && apt-get purge -y --auto-remove $buildDeps \ && rm -r /usr/src/php +#### WORKDIR /var/www/html EXPOSE 80 CMD ["apache2", "-DFOREGROUND"] +#### diff --git a/5.6/Dockerfile b/5.6/Dockerfile index 24370270..56fbfd00 100644 --- a/5.6/Dockerfile +++ b/5.6/Dockerfile @@ -1,20 +1,30 @@ -FROM buildpack-deps:jessie +FROM debian:jessie -RUN apt-get update && apt-get install -y curl && rm -r /var/lib/apt/lists/* +# persistent / runtime deps +RUN apt-get update && apt-get install -y curl libxml2 --no-install-recommends && rm -r /var/lib/apt/lists/* -#### -#### +#### +#### RUN gpg --keyserver pgp.mit.edu --recv-keys 6E4F6AB321FDC07F2C332E3AC2BF0BC433CFC8B3 0BD78B5F97500D450838F95DFE857D9A90D90EC1 ENV PHP_VERSION 5.6.2 -RUN set -x \ - && curl -SLO http://launchpadlibrarian.net/140087283/libbison-dev_2.7.1.dfsg-1_amd64.deb \ - && curl -SLO http://launchpadlibrarian.net/140087282/bison_2.7.1.dfsg-1_amd64.deb \ - && dpkg -i libbison-dev_2.7.1.dfsg-1_amd64.deb \ - && dpkg -i bison_2.7.1.dfsg-1_amd64.deb \ - && rm *.deb \ +RUN buildDeps=" \ + $PHP_EXTRA_BUILD_DEPS \ + build-essential \ + bzip2 \ + file \ + libcurl4-openssl-dev \ + libpng12-dev \ + libreadline6-dev \ + libssl-dev \ + libxml2-dev \ + m4 \ + pkg-config \ + "; \ + set -x \ + && apt-get update && apt-get install -y $buildDeps --no-install-recommends && rm -rf /var/lib/apt/lists/* \ && curl -SL "http://php.net/get/php-$PHP_VERSION.tar.bz2/from/this/mirror" -o php.tar.bz2 \ && curl -SL "http://php.net/get/php-$PHP_VERSION.tar.bz2.asc/from/this/mirror" -o php.tar.bz2.asc \ && gpg --verify php.tar.bz2.asc \ @@ -23,17 +33,21 @@ RUN set -x \ && rm php.tar.bz2* \ && cd /usr/src/php \ && ./configure --disable-cgi \ - $(command -v apxs2 > /dev/null 2>&1 && echo '--with-apxs2' || true) \ + $PHP_EXTRA_CONFIGURE_ARGS \ --with-curl \ --with-gd \ --with-mysql \ --with-mysqli \ --with-openssl \ --with-pdo-mysql \ + --with-readline \ --with-zlib \ && make -j"$(nproc)" \ && make install \ - && dpkg -r bison libbison-dev \ + && { find /usr/local/bin /usr/local/sbin -type f -executable -exec strip --strip-all '{}' + || true; } \ + && apt-get purge -y --auto-remove $buildDeps \ && rm -r /usr/src/php +#### CMD ["php", "-a"] +#### diff --git a/5.6/apache/Dockerfile b/5.6/apache/Dockerfile index 64aef64c..bd5beb81 100644 --- a/5.6/apache/Dockerfile +++ b/5.6/apache/Dockerfile @@ -1,9 +1,10 @@ -FROM buildpack-deps:jessie +FROM debian:jessie -RUN apt-get update && apt-get install -y curl && rm -r /var/lib/apt/lists/* +# persistent / runtime deps +RUN apt-get update && apt-get install -y curl libxml2 --no-install-recommends && rm -r /var/lib/apt/lists/* -#### -RUN apt-get update && apt-get install -y apache2-bin apache2-dev apache2.2-common --no-install-recommends && rm -rf /var/lib/apt/lists/* +#### +RUN apt-get update && apt-get install -y apache2-bin apache2.2-common --no-install-recommends && rm -rf /var/lib/apt/lists/* RUN rm -rf /var/www/html && mkdir -p /var/lock/apache2 /var/run/apache2 /var/log/apache2 /var/www/html && chown -R www-data:www-data /var/lock/apache2 /var/run/apache2 /var/log/apache2 /var/www/html @@ -12,18 +13,31 @@ RUN a2dismod mpm_event && a2enmod mpm_prefork RUN mv /etc/apache2/apache2.conf /etc/apache2/apache2.conf.dist COPY apache2.conf /etc/apache2/apache2.conf -#### +# it'd be nice if we could not COPY apache2.conf until the end of the Dockerfile, but its contents are checked by PHP during compilation + +ENV PHP_EXTRA_BUILD_DEPS apache2-dev +ENV PHP_EXTRA_CONFIGURE_ARGS --with-apxs2 +#### RUN gpg --keyserver pgp.mit.edu --recv-keys 6E4F6AB321FDC07F2C332E3AC2BF0BC433CFC8B3 0BD78B5F97500D450838F95DFE857D9A90D90EC1 ENV PHP_VERSION 5.6.2 -RUN set -x \ - && curl -SLO http://launchpadlibrarian.net/140087283/libbison-dev_2.7.1.dfsg-1_amd64.deb \ - && curl -SLO http://launchpadlibrarian.net/140087282/bison_2.7.1.dfsg-1_amd64.deb \ - && dpkg -i libbison-dev_2.7.1.dfsg-1_amd64.deb \ - && dpkg -i bison_2.7.1.dfsg-1_amd64.deb \ - && rm *.deb \ +RUN buildDeps=" \ + $PHP_EXTRA_BUILD_DEPS \ + build-essential \ + bzip2 \ + file \ + libcurl4-openssl-dev \ + libpng12-dev \ + libreadline6-dev \ + libssl-dev \ + libxml2-dev \ + m4 \ + pkg-config \ + "; \ + set -x \ + && apt-get update && apt-get install -y $buildDeps --no-install-recommends && rm -rf /var/lib/apt/lists/* \ && curl -SL "http://php.net/get/php-$PHP_VERSION.tar.bz2/from/this/mirror" -o php.tar.bz2 \ && curl -SL "http://php.net/get/php-$PHP_VERSION.tar.bz2.asc/from/this/mirror" -o php.tar.bz2.asc \ && gpg --verify php.tar.bz2.asc \ @@ -32,20 +46,24 @@ RUN set -x \ && rm php.tar.bz2* \ && cd /usr/src/php \ && ./configure --disable-cgi \ - $(command -v apxs2 > /dev/null 2>&1 && echo '--with-apxs2' || true) \ + $PHP_EXTRA_CONFIGURE_ARGS \ --with-curl \ --with-gd \ --with-mysql \ --with-mysqli \ --with-openssl \ --with-pdo-mysql \ + --with-readline \ --with-zlib \ && make -j"$(nproc)" \ && make install \ - && dpkg -r bison libbison-dev \ + && { find /usr/local/bin /usr/local/sbin -type f -executable -exec strip --strip-all '{}' + || true; } \ + && apt-get purge -y --auto-remove $buildDeps \ && rm -r /usr/src/php +#### WORKDIR /var/www/html EXPOSE 80 CMD ["apache2", "-DFOREGROUND"] +#### diff --git a/apache-Dockerfile-block-1 b/apache-Dockerfile-block-1 new file mode 100644 index 00000000..ed8264c1 --- /dev/null +++ b/apache-Dockerfile-block-1 @@ -0,0 +1,13 @@ +RUN apt-get update && apt-get install -y apache2-bin apache2.2-common --no-install-recommends && rm -rf /var/lib/apt/lists/* + +RUN rm -rf /var/www/html && mkdir -p /var/lock/apache2 /var/run/apache2 /var/log/apache2 /var/www/html && chown -R www-data:www-data /var/lock/apache2 /var/run/apache2 /var/log/apache2 /var/www/html + +# Apache + PHP requires preforking Apache for best results +RUN a2dismod mpm_event && a2enmod mpm_prefork + +RUN mv /etc/apache2/apache2.conf /etc/apache2/apache2.conf.dist +COPY apache2.conf /etc/apache2/apache2.conf +# it'd be nice if we could not COPY apache2.conf until the end of the Dockerfile, but its contents are checked by PHP during compilation + +ENV PHP_EXTRA_BUILD_DEPS apache2-dev +ENV PHP_EXTRA_CONFIGURE_ARGS --with-apxs2 diff --git a/apache-Dockerfile-block-2 b/apache-Dockerfile-block-2 new file mode 100644 index 00000000..0dd7f61e --- /dev/null +++ b/apache-Dockerfile-block-2 @@ -0,0 +1,4 @@ +WORKDIR /var/www/html + +EXPOSE 80 +CMD ["apache2", "-DFOREGROUND"] diff --git a/update.sh b/update.sh index 789f369d..5c7b2545 100755 --- a/update.sh +++ b/update.sh @@ -31,24 +31,16 @@ for version in "${versions[@]}"; do exit 1 fi - awk '$1 != "CMD" { print } $1 == "####" && c == 0 { c = 1; system("cat") }' "$version/Dockerfile" > "$version/apache/Dockerfile" <<-'EOD' - RUN apt-get update && apt-get install -y apache2-bin apache2-dev apache2.2-common --no-install-recommends && rm -rf /var/lib/apt/lists/* - - RUN rm -rf /var/www/html && mkdir -p /var/lock/apache2 /var/run/apache2 /var/log/apache2 /var/www/html && chown -R www-data:www-data /var/lock/apache2 /var/run/apache2 /var/log/apache2 /var/www/html - - # Apache + PHP requires preforking Apache for best results - RUN a2dismod mpm_event && a2enmod mpm_prefork - - RUN mv /etc/apache2/apache2.conf /etc/apache2/apache2.conf.dist - COPY apache2.conf /etc/apache2/apache2.conf - EOD - - cat >> "$version/apache/Dockerfile" <<-'EOD' - WORKDIR /var/www/html - - EXPOSE 80 - CMD ["apache2", "-DFOREGROUND"] - EOD + for variant in apache; do + echo "Generating $version/$variant/Dockerfile from $variant-Dockerfile-block-*" + awk ' + $1 == "####" { ia = 0 } + !ia { print } + $1 == "####" { ia = 1; ab++; ac = 0 } + ia { ac++ } + ia && ac == 1 { system("cat '$variant'-Dockerfile-block-" ab) } + ' "$version/Dockerfile" > "$version/$variant/Dockerfile" + done ( set -x