• Dockerfile 构建 php8


    官方的 php8 镜像基本满足开发需要,但有时却缺扩展,有两种选择,一是在容器内部去安装,二是在原来的基础上重新构建镜像。

    基于 php:8.0-fpm-buster 来说,原镜像自带了几个官方的 shll 脚本,地址: https://github.com/docker-library/php/tree/deb4a80b409c21ecdd2b884142fab51b48a9b3cb/8.0/buster/fpm

    docker-php-ext-configure :配置安装参数,即生成 ./configure --enable-php-fpm 之类的

    docker-php-ext-install :从源码包安装扩展

    docker-php-ext-enable :开启扩展,即配置写入 php.ini

    docker-php-entrypoint :这个是进入点,大概意思是,如果启动镜像时,如:docker run --name test -d php:8.0 cmd 如果最后的 cmd 是以 “-” 开头则表示它只是作为 php-fpm 的一个参数,运行 php-fpm cmd,否则运行 cmd

    下面 php 安装扩展的几种方式,根据需要选择。

    FROM php:8.0-fpm-buster
    
    #编译安装核心扩展
    RUN apt-get update && apt-get install -y 
        libfreetype6-dev 
        libjpeg62-turbo-dev 
        libpng-dev 
        && docker-php-ext-configure gd --with-freetype --with-jpeg 
        && docker-php-ext-install -j$(nproc) gd
    
    #pecl 安装扩展
    RUN pecl install redis-5.3.2 
        && pecl install xdebug-2.8.1 
        && docker-php-ext-enable redis xdebug
    
    
    #从源码包安装扩展
    RUN curl -fsSL 'https://xcache.lighttpd.net/pub/Releases/3.2.0/xcache-3.2.0.tar.gz' -o xcache.tar.gz 
        && mkdir -p /tmp/xcache 
        && tar -xf xcache.tar.gz -C /tmp/xcache --strip-components=1 
        && rm xcache.tar.gz 
        && docker-php-ext-configure /tmp/xcache --enable-xcache 
        && docker-php-ext-install /tmp/xcache 
        && rm -r /tmp/xcache

    我的 Dockerfile 如下:

    FROM php:8.0-fpm-buster
    
    #更换源
    RUN    sed -i "s/deb.debian.org/mirrors.aliyun.com/g" /etc/apt/sources.list 
    
    #编译安装核心扩展 gd
    RUN apt-get update &&
        apt-get install -y     libfreetype6-dev libjpeg62-turbo-dev libpng-dev &&
        docker-php-ext-configure gd --with-freetype --with-jpeg &&
        docker-php-ext-install -j$(nproc) gd
    
    #pecl 安装扩展 redis
    RUN pecl install redis-5.3.2 
        && docker-php-ext-enable redis

    进行到 Dockerfile 目录,执行  docker build -t zbseoag/php:8.0 . 就可以了。运行容器之后,进入容器,php -m 查看一下扩展有没有装成功。

     
  • 相关阅读:
    react 编写日历组件
    腾讯地图打开地图选取位置 withMap
    react 动态修改 document.title
    axios 中断请求
    react 使用 react-loadable分包
    http Authorization
    @media screen媒体查询
    CSS规范
    布局和WEB性能
    CSS 标签的分类,及显示模式
  • 原文地址:https://www.cnblogs.com/zbseoag/p/14168420.html
Copyright © 2020-2023  润新知