updaet
This commit is contained in:
parent
ea168ccb29
commit
dc7ff46b2c
10
Dockerfile
10
Dockerfile
@ -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
|
||||
|
||||
|
@ -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
|
Loading…
Reference in New Issue
Block a user