docker构建hyperf环境

一,构建hyperf 镜像

官网git https://github.com/hyperf/hyperf-docker

  1. 使用dockerfile构建镜像
    根据需要这里我使用8.1 swoole版本的镜像
    在/home/hyperfdocker 目录中新建一个Dockerfile文件,将这个git上的Dockerfile内容复制粘贴进去
bash 复制代码
docker build -t hyperf:php8.1 .

因为我的网络没有科学上网,失败了,换另一种方法

  1. 进入docker镜像仓库下载hyperf官方镜像
    https://hub.docker.com/r/hyperf/hyperf

此处我们直接下载镜像

bash 复制代码
docker pull hyperf/hyperf:8.1-alpine-v3.11-swoole
docker images

二,生成容器

bash 复制代码
docker run -d --name hyperf -v 宿主机代码目录: 容器内代码目录 -p 宿主机端口:容器端口(默认9501) -it --privileged -u root hyperf/hyperf:7.4-alpine-v3.11-swool
bash 复制代码
docker run -d --name hyperf -v /home/hyperfdocker:/www -p 9701:9501 -it --privileged -u root --entrypoint /bin/sh hyperf/hyperf:8.1-alpine-v3.16-swoole

查看容器

三,安装hyperf并运行

进入容器

bash 复制代码
docker exec -it hyperf bash

cd到工作目录

bash 复制代码
cd /www

修改composer 国内阿里云源 加速下载 (如提示composer命令不存在,需要安装composer,或在宿主机执行)

bash 复制代码
composer config -g repo.packagist composer https://mirrors.aliyun.com/composer

通过composer下载安装代码

bash 复制代码
composer create-project hyperf/hyperf-skeleton

注意这里必须安装PHP >= 8.1,否则安装不成功一直报错

composer完成后cd到hyperf-skeleton目录下运行项目

bash 复制代码
php bin/hyperf.php start

注意这里有个坑,如果我们composer安装的时候选择安装了mysql,redis等模块,那就须要配置连接信息,否则会一直报错,start启动不起来(mysql不会报错)

假设我们开启了mysql模块,我本机已经启动了一个mysql容器,我们就去修改配置文件,然后连接mysql数据库
容器之间的互联是使用共享网络指定共同的内网ip进行桥接连通,第一步创建共享网络。第二步容器运行时指定好网络就行

  • 查看容器列表
bash 复制代码
 docker ps -a
  • 查看容器网络
  • 查看docker 镜像/容器的元数据
bash 复制代码
docker inspect mysql5

前面其实我已经安装了一个lnmp环境,这里我想就用hyperf容器来联通lnmp环境中的mysql容器

bash 复制代码
docker inspect lnmp_default

这里我们采用创建自定义网络的方式来连通,通过创建自定义网络,可以为容器提供一个独立的网络环境,使得容器可以相互通信,并与其他网络资源进行交互。自定义网络提供了更灵活和可扩展的容器互联方式,相对于过时的 --link 参数更加推荐和强大

创建自定义网络后,可以将容器连接到该网络,并使用容器名称或服务名称进行容器间通信。这种方式更加标准化,具备更好的扩展性和管理能力。

所以我们只需要将hyperf 容器 加入 mysql5容器网络lnmp_default即可,这里也有两种方法,一种是在 run初始化容器的是使用 --network lnmp_default 声明他的网络,另外一种就是容器已经run好了,那现在直接加入就行了

bash 复制代码
docker network connect lnmp_default hyperf

然后再使用 docker inspect lnmp_default 查看,发现已经包含进来了

如要要验证,可以使用两边互相ping通来测试

  • hyperf配置mysql连接
    修改.env配置文件

注意,
这里面的db_host 是刚刚查看的mysql5 容器的ip
db_port 是容器内部端口不是映射端口


在项目目录\hyperf-skeleton\config目录下打开routes.php文件,添加路由配置

php 复制代码
Router::addGroup('/index/',function (){
    Router::get('test','App\Controller\IndexController@test');
});

在项目目录\hyperf-skeleton\app\Controller下找到IndexController.php文件,新增一个action,文件内容修改如下

php 复制代码
public function test()
    {
        $users = Db::select('SELECT * FROM `user`');  //  返回array

        return [
            'users' => $users,
        ];
    }
相关推荐
阿梦Anmory8 分钟前
Ubuntu配置代理最详细教程
linux·运维·ubuntu
呉師傅22 分钟前
【使用技巧】Adobe Photoshop 2024调整缩放与布局125%后出现点菜单项漂移问题的简单处理
运维·服务器·windows·adobe·电脑·photoshop
heartbeat..25 分钟前
JVM 性能调优流程实战:从开发规范到生产应急排查
java·运维·jvm·性能优化·设计规范
小章UPUP38 分钟前
Kubernetes (K8s) 与 Podman 的比较
容器·kubernetes·podman
忆~遂愿42 分钟前
CANN metadef 核心解析:计算图原型定义、算子元数据抽象与异构系统互操作机制
docker·容器
小Tomkk1 小时前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
赌博羊1 小时前
ImportError: /lib/x86_64-linux-gnu/libc.so.6: version `GLIBC_2.32‘ not found
linux·运维·gnu
消失的旧时光-19431 小时前
Linux 入门核心命令清单(工程版)
linux·运维·服务器
艾莉丝努力练剑1 小时前
【Linux:文件】Ext系列文件系统(初阶)
大数据·linux·运维·服务器·c++·人工智能·算法
小天源1 小时前
Cacti在Debian/Ubuntu中安装及其使用
运维·ubuntu·debian·cacti