nginx-php-fpm-docker (8.0-swoole-loader)

Published 2024-12-01 16:23:31 +00:00 by ivampiresp in packaged/nginx-php-fpm-docker

Installation

docker pull leafdev.top/packaged/nginx-php-fpm-docker:8.0-swoole-loader
sha256:c2d4c2a198e47403e4d7342baf3e9670f7a2f9b7cc41f60562d98f46538f95cc

Image Layers

ADD file:e9f63d1defc55282fec6525ac2886c735dc2189e34105d7fe64c2420d6673922 in /
CMD ["bash"]
/bin/sh -c set -eux; { echo 'Package: php*'; echo 'Pin: release *'; echo 'Pin-Priority: -1'; } > /etc/apt/preferences.d/no-debian-php
ENV PHPIZE_DEPS=autoconf dpkg-dev file g++ gcc libc-dev make pkg-config re2c
/bin/sh -c set -eux; apt-get update; apt-get install -y --no-install-recommends $PHPIZE_DEPS ca-certificates curl xz-utils ; rm -rf /var/lib/apt/lists/*
ENV PHP_INI_DIR=/usr/local/etc/php
/bin/sh -c set -eux; mkdir -p "$PHP_INI_DIR/conf.d"; [ ! -d /var/www/html ]; mkdir -p /var/www/html; chown www-data:www-data /var/www/html; chmod 1777 /var/www/html
ENV PHP_CFLAGS=-fstack-protector-strong -fpic -fpie -O2 -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64
ENV PHP_CPPFLAGS=-fstack-protector-strong -fpic -fpie -O2 -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64
ENV PHP_LDFLAGS=-Wl,-O1 -pie
ENV GPG_KEYS=1729F83938DA44E27BA0F4D3DBDB397470D12172 BFDDD28642824F8118EF77909B67A5C12229118F 2C16C765DBE54A088130F1BC4B9B5F600B55F3B4 39B641343D8C104B2B146DC3F9C39DC0B9698544
ENV PHP_VERSION=8.0.30
ENV PHP_URL=https://www.php.net/distributions/php-8.0.30.tar.xz PHP_ASC_URL=https://www.php.net/distributions/php-8.0.30.tar.xz.asc
ENV PHP_SHA256=216ab305737a5d392107112d618a755dc5df42058226f1670e9db90e77d777d9
/bin/sh -c set -eux; savedAptMark="$(apt-mark showmanual)"; apt-get update; apt-get install -y --no-install-recommends gnupg; rm -rf /var/lib/apt/lists/*; mkdir -p /usr/src; cd /usr/src; curl -fsSL -o php.tar.xz "$PHP_URL"; if [ -n "$PHP_SHA256" ]; then echo "$PHP_SHA256 *php.tar.xz" | sha256sum -c -; fi; if [ -n "$PHP_ASC_URL" ]; then curl -fsSL -o php.tar.xz.asc "$PHP_ASC_URL"; export GNUPGHOME="$(mktemp -d)"; for key in $GPG_KEYS; do gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key"; done; gpg --batch --verify php.tar.xz.asc php.tar.xz; gpgconf --kill all; rm -rf "$GNUPGHOME"; fi; apt-mark auto '.*' > /dev/null; apt-mark manual $savedAptMark > /dev/null; apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false
COPY file:ce57c04b70896f77cc11eb2766417d8a1240fcffe5bba92179ec78c458844110 in /usr/local/bin/
/bin/sh -c set -eux; savedAptMark="$(apt-mark showmanual)"; apt-get update; apt-get install -y --no-install-recommends libargon2-dev libcurl4-openssl-dev libonig-dev libreadline-dev libsodium-dev libsqlite3-dev libssl-dev libxml2-dev zlib1g-dev ; export CFLAGS="$PHP_CFLAGS" CPPFLAGS="$PHP_CPPFLAGS" LDFLAGS="$PHP_LDFLAGS" ; docker-php-source extract; cd /usr/src/php; gnuArch="$(dpkg-architecture --query DEB_BUILD_GNU_TYPE)"; debMultiarch="$(dpkg-architecture --query DEB_BUILD_MULTIARCH)"; if [ ! -d /usr/include/curl ]; then ln -sT "/usr/include/$debMultiarch/curl" /usr/local/include/curl; fi; ./configure --build="$gnuArch" --with-config-file-path="$PHP_INI_DIR" --with-config-file-scan-dir="$PHP_INI_DIR/conf.d" --enable-option-checking=fatal --with-mhash --with-pic --enable-ftp --enable-mbstring --enable-mysqlnd --with-password-argon2 --with-sodium=shared --with-pdo-sqlite=/usr --with-sqlite3=/usr --with-curl --with-iconv --with-openssl --with-readline --with-zlib --disable-phpdbg --with-pear $(test "$gnuArch" = 's390x-linux-gnu' && echo '--without-pcre-jit') --with-libdir="lib/$debMultiarch" --disable-cgi --enable-fpm --with-fpm-user=www-data --with-fpm-group=www-data ; make -j "$(nproc)"; find -type f -name '*.a' -delete; make install; find /usr/local -type f -perm '/0111' -exec sh -euxc ' strip --strip-all "$@" || : ' -- '{}' + ; make clean; cp -v php.ini-* "$PHP_INI_DIR/"; cd /; docker-php-source delete; apt-mark auto '.*' > /dev/null; [ -z "$savedAptMark" ] || apt-mark manual $savedAptMark; find /usr/local -type f -executable -exec ldd '{}' ';' | awk '/=>/ { so = $(NF-1); if (index(so, "/usr/local/") == 1) { next }; gsub("^/(usr/)?", "", so); print so }' | sort -u | xargs -r dpkg-query --search | cut -d: -f1 | sort -u | xargs -r apt-mark manual ; apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; rm -rf /var/lib/apt/lists/*; pecl update-channels; rm -rf /tmp/pear ~/.pearrc; php --version
COPY multi:869bde9dbeae74886a05c9e2107b3e3b4877116db8c6d9adbaff2719f9fb5262 in /usr/local/bin/
/bin/sh -c docker-php-ext-enable sodium
ENTRYPOINT ["docker-php-entrypoint"]
WORKDIR /var/www/html
/bin/sh -c set -eux; cd /usr/local/etc; if [ -d php-fpm.d ]; then sed 's!=NONE/!=!g' php-fpm.conf.default | tee php-fpm.conf > /dev/null; cp php-fpm.d/www.conf.default php-fpm.d/www.conf; else mkdir php-fpm.d; cp php-fpm.conf.default php-fpm.d/www.conf; { echo '[global]'; echo 'include=etc/php-fpm.d/*.conf'; } | tee php-fpm.conf; fi; { echo '[global]'; echo 'error_log = /proc/self/fd/2'; echo; echo '; https://github.com/docker-library/php/pull/725#issuecomment-443540114'; echo 'log_limit = 8192'; echo; echo '[www]'; echo '; php-fpm closes STDOUT on startup, so sending logs to /proc/self/fd/1 does not work.'; echo '; https://bugs.php.net/bug.php?id=73886'; echo 'access.log = /proc/self/fd/2'; echo; echo 'clear_env = no'; echo; echo '; Ensure worker stdout and stderr are sent to the main error log.'; echo 'catch_workers_output = yes'; echo 'decorate_workers_output = no'; } | tee php-fpm.d/docker.conf; { echo '[global]'; echo 'daemonize = no'; echo; echo '[www]'; echo 'listen = 9000'; } | tee php-fpm.d/zz-docker.conf; mkdir -p "$PHP_INI_DIR/conf.d"; { echo '; https://github.com/docker-library/php/issues/878#issuecomment-938595965'; echo 'fastcgi.logging = Off'; } > "$PHP_INI_DIR/conf.d/docker-fpm.ini"
STOPSIGNAL SIGQUIT
EXPOSE 9000
CMD ["php-fpm"]
ARG WORKDIR=/var/www
ENV DOCUMENT_ROOT=/var/www
ENV LARAVEL_PROCS_NUMBER=1
ENV DOMAIN=_
ENV CLIENT_MAX_BODY_SIZE=15M
ARG GROUP_ID=1000
ARG USER_ID=1000
ENV USER_NAME=www-data
ARG GROUP_NAME=www-data
ENV TZ=Asia/Shanghai
RUN |4 WORKDIR=/var/www GROUP_ID=1000 USER_ID=1000 GROUP_NAME=www-data /bin/sh -c apt-get update && apt-get install -y curl libfreetype6-dev libjpeg62-turbo-dev libmemcached-dev libzip-dev libpng-dev libonig-dev libxml2-dev librdkafka-dev libpq-dev libgmp-dev zlib1g-dev libssl-dev libcurl4-openssl-dev libcurl4 libwebp-dev libjpeg-dev libfreetype6-dev libjpeg62-turbo-dev libmemcached-dev zip unzip sqlite3 nano cron nginx # buildkit
RUN |4 WORKDIR=/var/www GROUP_ID=1000 USER_ID=1000 GROUP_NAME=www-data /bin/sh -c apt-get clean && rm -rf /var/lib/apt/lists/* # buildkit
RUN |4 WORKDIR=/var/www GROUP_ID=1000 USER_ID=1000 GROUP_NAME=www-data /bin/sh -c docker-php-ext-configure gd --with-freetype --with-jpeg --with-webp # buildkit
ADD --chmod=0755 https://github.com/mlocati/docker-php-extension-installer/releases/latest/download/install-php-extensions /usr/local/bin/ # buildkit
COPY src/ext/swoole_loader80.so /usr/local/lib/php/extensions/no-debug-non-zts-20200930 # buildkit
COPY src/php-fpm /etc/init.d/php-fpm # buildkit
RUN |4 WORKDIR=/var/www GROUP_ID=1000 USER_ID=1000 GROUP_NAME=www-data /bin/sh -c docker-php-ext-install -j$(nproc) pdo_mysql opcache intl gmp mysqli curl zip mbstring exif pdo pdo_pgsql gd && docker-php-ext-enable pdo_mysql opcache intl gmp mysqli curl zip mbstring exif pdo pdo_pgsql gd && install-php-extensions redis pcntl && docker-php-ext-enable redis pcntl && docker-php-ext-enable swoole_loader80 && rm /usr/local/bin/install-php-extensions && apt clean && rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/{apt,dpkg,cache,log}/ && rm -rf /tmp/* && curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer # buildkit
WORKDIR /var/www
ADD src/index.php /var/www/index.php # buildkit
ADD src/php.ini /usr/local/etc/php/conf.d/ # buildkit
COPY src/entrypoint.sh /usr/local/bin/ # buildkit
RUN |4 WORKDIR=/var/www GROUP_ID=1000 USER_ID=1000 GROUP_NAME=www-data /bin/sh -c chmod +x /usr/local/bin/entrypoint.sh && ln -s /usr/local/bin/entrypoint.sh / && rm -rf /etc/nginx/conf.d/default.conf && rm -rf /etc/nginx/sites-enabled/default && rm -rf /etc/nginx/sites-available/default && rm -rf /etc/nginx/nginx.conf # buildkit
COPY src/nginx.conf /etc/nginx/nginx.conf # buildkit
COPY src/default.conf /etc/nginx/conf.d/ # buildkit
COPY src/fpm-docker.conf /usr/local/etc/php-fpm.d/zz-docker.conf # buildkit
COPY src/www.conf /usr/local/etc/php-fpm.d/www.conf # buildkit
RUN |4 WORKDIR=/var/www GROUP_ID=1000 USER_ID=1000 GROUP_NAME=www-data /bin/sh -c usermod -u ${USER_ID} ${USER_NAME} && groupmod -g ${USER_ID} ${GROUP_NAME} && mkdir -p /var/log/nginx && mkdir -p /var/cache/nginx && chown -R ${USER_NAME}:${GROUP_NAME} /var/www && chown -R ${USER_NAME}:${GROUP_NAME} /var/log/ && chown -R ${USER_NAME}:${GROUP_NAME} $PHP_INI_DIR/conf.d/ && touch /var/run/nginx.pid && chown -R $USER_NAME:$USER_NAME /var/cache/nginx && chown -R $USER_NAME:$USER_NAME /var/lib/nginx/ && chown -R $USER_NAME:$USER_NAME /var/run/nginx.pid && chown -R $USER_NAME:$USER_NAME /etc/nginx/nginx.conf && chown -R $USER_NAME:$USER_NAME /etc/nginx/conf.d/ && chown -R ${USER_NAME}:${GROUP_NAME} /tmp # buildkit
EXPOSE map[80/tcp:{}]
ENTRYPOINT ["entrypoint.sh"]
Details
Container
2024-12-01 16:23:31 +00:00
2
OCI / Docker
linux/amd64
246 MiB
Versions (4) View all
8.2 2024-12-01
8.0-swoole-loader 2024-12-01
8.0 2024-12-01
7.4 2024-12-01