docker创建hyperf php-8.1 + swoole5.0

FROM php:8.1.22-fpm-alpine3.16
ARG swoole_ver
ENV SWOOLE_VER=${swoole_ver:-"v5.0.1"}
ARG redis_ver
ENV REDIS_VER=${redis_ver:-"5.2.0"}

RUN set -ex \
    && cd /tmp \
    && sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories \
    && apk update \
    && apk add vim git autoconf openssl-dev build-base zlib-dev re2c libpng-dev oniguruma-dev \
    && docker-php-ext-install bcmath
    
RUN cd /tmp \
    && wget https://mirrors.aliyun.com/composer/composer.phar \
    && chmod u+x composer.phar \
    && mv composer.phar /usr/local/bin/composer \
    && composer config -g repo.packagist composer https://mirrors.aliyun.com/composer \
    && echo 'export PATH="$PATH:$HOME/.composer/vendor/bin"' >> ~/.bashrc

RUN php -m \
    && docker-php-ext-install gd pdo_mysql mysqli sockets pcntl \
    && php -m

RUN cd /tmp \
    # from mirrors
    && git clone https://gitee.com/swoole/swoole.git swoole \
    && cd swoole \
    && git checkout ${SWOOLE_VER} \
    && phpize \
    && ./configure --enable-openssl --enable-sockets --enable-http2 --enable-mysqlnd \
    && make \
    && make install \
    && docker-php-ext-enable swoole \
    && php -m \
    && php --ri swoole

RUN cd /tmp \
    # from mirrors
    && git clone https://gitee.com/mirrors/phpredis.git phpredis \
    && cd phpredis \
    && phpize \
    && ./configure \
    && make \
    && make install \
    && docker-php-ext-enable redis \
    && php -m \
    && php --ri redis

RUN cd /tmp \
    && php -v \
    && php -m 
    
EXPOSE 9501
WORKDIR /home/www

这是构建dockerfile的文件

然后你就可以在当前文件夹中执行以下命令

docker build  -t hyperf-docker .

就创建了一个可以使用hyperf环境的docker容器

然后可以执行以下命令使项目跑起来

php -d swoole.use_shortname=off bin/hyperf.php start

如果不想加参数可以进行一下操作

cd /usr/local/etc/php 
copy php.ini-development php.ini
vi php.ini
#在文件中加入一行 ,然后esc  :wq保存并退出
swoole.use_shortname=off

然后就可以执行启动项目

php bin/hyperf.php start

如果你的容器访问不到mysql服务

可以使用以下方法,首先使用以下命令查看有没有网络

docker network ls

如果没有有可以使用如下命令创建一个网络

docker network create -d bridge esnetwork

bridge
bridge模式:docker网络隔离基于网络命名空间,在物理机上创建docker容器时会为每一个docker容器分配网络命名空间,并且把容器IP桥接到物理机的虚拟网桥上。

bridge 存在的目的:隔离各个容器,使得每个容器的端口号都是隔离的。如果不隔离开来,那么容器将和宿主机,容器和容器间都会发生端口占用的情况。
然后把mysql容器和hyperf容器关联到同一个网络下

docker network connect esnetwork mysql

docker network connect esnetwork hyperf

##最后修改配置文件

DB_DRIVER=mysql
DB_HOST=mymysql-serve
DB_PORT=3306
DB_DATABASE=yfd_saas
DB_USERNAME=root
DB_PASSWORD=123456
DB_CHARSET=utf8mb4
DB_COLLATION=utf8mb4_unicode_ci
DB_PREFIX=
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值