This commit is contained in:
Tinywan 2023-10-11 17:45:21 +08:00
parent ea168ccb29
commit dc7ff46b2c
2 changed files with 114 additions and 123 deletions

View File

@ -6,20 +6,20 @@ LABEL Maintainer="ShaoBo Wan (Tinywan) <756684177@qq.com>" \
Description="Webman Lightweight container with PHP 8.2.11 based on Alpine Linux."
# Container package : mirrors.163.com、mirrors.aliyun.com、mirrors.ustc.edu.cn
RUN sed -i "s/dl-cdn.alpinelinux.org/mirrors.ustc.edu.cn/g" /etc/apk/repositories
RUN sed -i "s/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g" /etc/apk/repositories
RUN cat /etc/issue
# Add basics first
RUN apk update && apk upgrade && apk add bash curl ca-certificates openssl openssh git nano libxml2-dev tzdata icu-dev openntpd libedit-dev libzip-dev libjpeg-turbo-dev libpng-dev freetype-dev autoconf dpkg-dev dpkg file g++ gcc libc-dev make pkgconf re2c pcre-dev openssl-dev libffi-dev libressl-dev libevent-dev zlib-dev libtool automake supervisor
RUN apk update && apk add bash curl ca-certificates openssl openssh git nano libxml2-dev tzdata icu-dev openntpd libedit-dev libzip-dev libjpeg-turbo-dev libpng-dev freetype-dev autoconf dpkg-dev dpkg file g++ gcc libc-dev make pkgconf re2c pcre-dev libffi-dev libressl-dev libevent-dev zlib-dev libtool automake supervisor
# RUN apt-get update && apt-get upgrade && apt-get install bash curl ca-certificates openssl openssh git nano libxml2-dev tzdata icu-dev openntpd libedit-dev libzip-dev libjpeg-turbo-dev libpng-dev freetype-dev autoconf dpkg-dev dpkg file g++ gcc libc-dev make pkgconf re2c pcre-dev openssl-dev libffi-dev libressl-dev libevent-dev zlib-dev libtool automake supervisor
COPY ./extension /tmp/extension
WORKDIR /tmp/extension
RUN chmod +x install.sh \
&& sh install.sh \
&& rm -rf /tmp/extension
&& sh install.sh
# && rm -rf /tmp/extension
RUN php -m
@ -48,8 +48,6 @@ USER root
# Add application
WORKDIR /app
SHELL ["/bin/bash", "-c"]
# Expose the port nginx is reachable on
EXPOSE 8080

View File

@ -2,7 +2,6 @@
export MC="-j$(nproc)"
echo
echo "============================================"
echo "Install extensions from : install.sh"
echo "PHP version : ${PHP_VERSION}"
@ -10,7 +9,7 @@ echo "Work directory : ${PWD}"
echo "============================================"
echo
export EXTENSIONS=",gd,bcmath,pdo,mysqli,pdo_mysql,redis,bz2,calendar,opcache,pcntl,sockets,amqp,zip,soap,event,"
export EXTENSIONS="gd,bcmath,pdo,mysqli,pdo_mysql,redis,bz2,calendar,opcache,pcntl,sockets,amqp,zip,soap,event,"
#
# Check if current php version is greater than or equal to
@ -19,25 +18,24 @@ export EXTENSIONS=",gd,bcmath,pdo,mysqli,pdo_mysql,redis,bz2,calendar,opcache,pc
# For example, to check if current php is greater than or
# equal to PHP 7.0:
#
# isPhpVersionGreaterOrEqual 7 0
# isPhpVersionGreaterOrEqual 8 0
#
# Param 1: Specific PHP Major version
# Param 2: Specific PHP Minor version
# Return : 1 if greater than or equal to, 0 if less than
#
isPhpVersionGreaterOrEqual()
{
local PHP_MAJOR_VERSION=$(php -r "echo PHP_MAJOR_VERSION;")
local PHP_MINOR_VERSION=$(php -r "echo PHP_MINOR_VERSION;")
isPhpVersionGreaterOrEqual() {
# local PHP_MAJOR_VERSION=$(php -r "echo PHP_MAJOR_VERSION;")
# local PHP_MINOR_VERSION=$(php -r "echo PHP_MINOR_VERSION;")
if [[ "$PHP_MAJOR_VERSION" -gt "$1" || "$PHP_MAJOR_VERSION" -eq "$1" && "$PHP_MINOR_VERSION" -ge "$2" ]]; then
return 1;
else
# if [[ "$PHP_MAJOR_VERSION" -gt "$1" || "$PHP_MAJOR_VERSION" -eq "$1" && "$PHP_MINOR_VERSION" -ge "$2" ]]; then
# return 1;
# else
# return 0;
# fi
return 0;
fi
}
#
# Install extension from package file(.tgz),
# For example:
@ -47,19 +45,17 @@ isPhpVersionGreaterOrEqual()
# Param 1: Package name with version
# Param 2: enable options
#
installExtensionFromTgz()
{
installExtensionFromTgz() {
tgzName=$1
extensionName="${tgzName%%-*}"
mkdir ${extensionName}
tar -xf ${tgzName}.tgz -C ${extensionName} --strip-components=1
( cd ${extensionName} && phpize && ./configure && make ${MC} && make install )
(cd ${extensionName} && phpize && ./configure && make ${MC} && make install)
docker-php-ext-enable ${extensionName} $2
}
if [[ -z "${EXTENSIONS##*,pdo_mysql,*}" ]]; then
echo "---------- Install pdo_mysql ----------"
docker-php-ext-install ${MC} pdo_mysql
@ -158,14 +154,14 @@ fi
if [[ -z "${EXTENSIONS##*,pdo_pgsql,*}" ]]; then
echo "---------- Install pdo_pgsql ----------"
apk --no-cache add postgresql-dev \
&& docker-php-ext-install ${MC} pdo_pgsql
apk --no-cache add postgresql-dev &&
docker-php-ext-install ${MC} pdo_pgsql
fi
if [[ -z "${EXTENSIONS##*,pgsql,*}" ]]; then
echo "---------- Install pgsql ----------"
apk --no-cache add postgresql-dev \
&& docker-php-ext-install ${MC} pgsql
apk --no-cache add postgresql-dev &&
docker-php-ext-install ${MC} pgsql
fi
if [[ -z "${EXTENSIONS##*,oci8,*}" ]]; then
@ -191,7 +187,7 @@ fi
if [[ -z "${EXTENSIONS##*,gd,*}" ]]; then
echo "---------- Install gd ----------"
isPhpVersionGreaterOrEqual 7 4
isPhpVersionGreaterOrEqual 8 0
if [[ "$?" = "1" ]]; then
# "--with-xxx-dir" was removed from php 7.4,
@ -208,10 +204,10 @@ if [[ -z "${EXTENSIONS##*,gd,*}" ]]; then
libpng-dev \
libjpeg-turbo \
libjpeg-turbo-dev \
libwebp-dev \
&& docker-php-ext-configure gd ${options} \
&& docker-php-ext-install ${MC} gd \
&& apk del \
libwebp-dev &&
docker-php-ext-configure gd ${options} &&
docker-php-ext-install ${MC} gd &&
apk del \
freetype-dev \
libpng-dev \
libjpeg-turbo-dev
@ -351,9 +347,8 @@ if [[ -z "${EXTENSIONS##*,igbinary,*}" ]]; then
docker-php-ext-enable igbinary
fi
if [[ -z "${EXTENSIONS##*,yac,*}" ]]; then
isPhpVersionGreaterOrEqual 7 0
isPhpVersionGreaterOrEqual 8 0
if [[ "$?" = "1" ]]; then
echo "---------- Install yac ----------"
printf "\n" | pecl install yac-2.0.2
@ -375,9 +370,8 @@ if [[ -z "${EXTENSIONS##*,yar,*}" ]]; then
fi
if [[ -z "${EXTENSIONS##*,yaconf,*}" ]]; then
isPhpVersionGreaterOrEqual 7 0
isPhpVersionGreaterOrEqual 8 0
if [[ "$?" = "1" ]]; then
echo "---------- Install yaconf ----------"
printf "\n" | pecl install yaconf
@ -401,7 +395,7 @@ if [[ -z "${EXTENSIONS##*,varnish,*}" ]]; then
fi
if [[ -z "${EXTENSIONS##*,pdo_sqlsrv,*}" ]]; then
isPhpVersionGreaterOrEqual 7 1
isPhpVersionGreaterOrEqual 8 0
if [[ "$?" = "1" ]]; then
echo "---------- Install pdo_sqlsrv ----------"
apk add --no-cache unixodbc-dev
@ -431,17 +425,17 @@ if [[ -z "${EXTENSIONS##*,mcrypt,*}" ]]; then
if [[ "$?" = "1" ]]; then
echo "---------- Install mcrypt ----------"
apk add --no-cache libmcrypt-dev libmcrypt re2c
printf "\n" |pecl install mcrypt
printf "\n" | pecl install mcrypt
docker-php-ext-enable mcrypt
else
echo "---------- Install mcrypt ----------"
apk add --no-cache libmcrypt-dev \
&& docker-php-ext-install ${MC} mcrypt
apk add --no-cache libmcrypt-dev &&
docker-php-ext-install ${MC} mcrypt
fi
fi
if [[ -z "${EXTENSIONS##*,mysql,*}" ]]; then
isPhpVersionGreaterOrEqual 7 0
isPhpVersionGreaterOrEqual 8 0
if [[ "$?" = "1" ]]; then
echo "---------- mysql was REMOVED from PHP 7.0.0 ----------"
@ -472,7 +466,7 @@ fi
if [[ -z "${EXTENSIONS##*,redis,*}" ]]; then
echo "---------- Install redis ----------"
isPhpVersionGreaterOrEqual 7 4
isPhpVersionGreaterOrEqual 8 0
if [[ "$?" = "1" ]]; then
installExtensionFromTgz redis-5.3.4
else
@ -489,7 +483,7 @@ fi
if [[ -z "${EXTENSIONS##*,memcached,*}" ]]; then
echo "---------- Install memcached ----------"
apk add --no-cache libmemcached-dev zlib-dev
isPhpVersionGreaterOrEqual 7 0
isPhpVersionGreaterOrEqual 8 0
if [[ "$?" = "1" ]]; then
printf "\n" | pecl install memcached-3.1.3
@ -557,7 +551,6 @@ if [[ -z "${EXTENSIONS##*,yaf,*}" ]]; then
fi
fi
if [[ -z "${EXTENSIONS##*,swoole,*}" ]]; then
echo "---------- Install swoole ----------"
isPhpVersionGreaterOrEqual 7 0
@ -574,7 +567,7 @@ if [[ -z "${EXTENSIONS##*,zip,*}" ]]; then
# Fix: https://github.com/docker-library/php/issues/797
apk add --no-cache libzip-dev
isPhpVersionGreaterOrEqual 7 4
isPhpVersionGreaterOrEqual 8 0
if [[ "$?" != "1" ]]; then
docker-php-ext-configure zip --with-libzip=/usr/include
fi
@ -585,13 +578,13 @@ fi
if [[ -z "${EXTENSIONS##*,xhprof,*}" ]]; then
echo "---------- Install XHProf ----------"
isPhpVersionGreaterOrEqual 7 0
isPhpVersionGreaterOrEqual 8 0
if [[ "$?" = "1" ]]; then
mkdir xhprof \
&& tar -xf xhprof-2.2.0.tgz -C xhprof --strip-components=1 \
&& ( cd xhprof/extension/ && phpize && ./configure && make ${MC} && make install ) \
&& docker-php-ext-enable xhprof
mkdir xhprof &&
tar -xf xhprof-2.2.0.tgz -C xhprof --strip-components=1 &&
(cd xhprof/extension/ && phpize && ./configure && make ${MC} && make install) &&
docker-php-ext-enable xhprof
else
echo "---------- PHP Version>= 7.0----------"
fi
@ -600,7 +593,7 @@ fi
if [[ -z "${EXTENSIONS##*,xlswriter,*}" ]]; then
echo "---------- Install xlswriter ----------"
isPhpVersionGreaterOrEqual 7 0
isPhpVersionGreaterOrEqual 8 0
if [[ "$?" = "1" ]]; then
printf "\n" | pecl install xlswriter
@ -655,17 +648,17 @@ if [[ -z "${EXTENSIONS##*,sdebug,*}" ]]; then
isPhpVersionGreaterOrEqual 7 2
if [[ "$?" = "1" ]]; then
curl -SL "https://github.com/swoole/sdebug/archive/sdebug_2_9-beta.tar.gz" -o sdebug.tar.gz \
&& mkdir -p sdebug \
&& tar -xf sdebug.tar.gz -C sdebug --strip-components=1 \
&& rm sdebug.tar.gz \
&& ( \
cd sdebug \
&& phpize \
&& ./configure --enable-xdebug \
&& make clean && make && make install \
) \
&& docker-php-ext-enable xdebug
curl -SL "https://github.com/swoole/sdebug/archive/sdebug_2_9-beta.tar.gz" -o sdebug.tar.gz &&
mkdir -p sdebug &&
tar -xf sdebug.tar.gz -C sdebug --strip-components=1 &&
rm sdebug.tar.gz &&
(
cd sdebug &&
phpize &&
./configure --enable-xdebug &&
make clean && make && make install
) &&
docker-php-ext-enable xdebug
else
echo "---------- PHP Version>= 7.2----------"
fi
@ -673,7 +666,7 @@ fi
if [[ -z "${EXTENSIONS##*,protobuf,*}" ]]; then
echo "---------- Install protobuf ----------"
isPhpVersionGreaterOrEqual 7 2
isPhpVersionGreaterOrEqual 8 0
if [[ "$?" = "1" ]]; then
installExtensionFromTgz protobuf-3.13.0.1
@ -694,6 +687,6 @@ if [[ -z "${EXTENSIONS##*,grpc,*}" ]]; then
fi
if [ "${PHP_EXTENSIONS}" != "" ]; then
apk del .build-deps \
&& docker-php-source delete
apk del .build-deps &&
docker-php-source delete
fi