详解Docker 下开发 hyperf 完整使用示例

Hyperf官方网站
Hyperf 官方文档安装篇

1. docker 使用

  • docker search 列出 hyperf 镜像
  • docker pull 下载镜像到本地
  • 运行 镜像并且将目录挂载到当前目录下文件夹 内,同时依照 /bin/sh 的方式运行
  • 进入到 hyperf-skeleton 目录,此目录是和本地挂靠的
$ docker search hyperf 
$ docker pull hyperf/hyperf 
$ docker run -v $PWD/:/hyperf-skeleton -p 9501:9501 -it --entrypoint /bin/sh hyperf/hyperf
$ cd hyperf-skeleton

2. 镜像容器运行后,并在容器内安装 Composer

先下载 Composer 进 docker 容器内

$ wget https://mirrors.aliyun.com/composer/composer.phar

3. 修改执行权限

此操作是为了解决 Composer 不允许 root 权限执行的限制

同时为切换用户时,可以直接操作

生产环境下不推荐 777 授权方式

$ chmod -R 777 ./composer.phar

4. 移动 composer 至 bin 目录下面,并且改名为 composer

生产环境下不推荐 777 授权方式

$ mv composer.phar /usr/local/bin/composer

5. 修改 root 密码

同时因为不清楚 root 密码,我们直接先做好修改
密码需要重复输入两次,并且不会显示,请注意

$ passwd root

6. 可以查看一下是 linux 发行版版本(命令会有所区别)

官方的镜像为 Linux 的 alpine

$ cat /etc/os-release

7. 建立一个指定 GID 的组

官方的镜像为 Linux 的 alpine 和很多小伙伴用的 Centos 命令会有所区别
如果是自己的建立的镜像,按照发行版本命令走就好了

$ addgroup -g 10001 -S www

8. 建立一个指定 UID 的用户

指定 shell, 让它属于指定的用户组。

$ adduser www -u 20001 -D -S -s /bin/bash -G www

9. 让新建的用户可以使用 su - 到 root 用户下,

$ chmod 4755 /bin/busybox

10. 切换至 www 用户执行 composer

su www 切换用户
whoami 查看当前用户

$ su www
$ whoami

11. 将 Composer 镜像设置为阿里云镜像,用于加速国内下载速度

当然是否使用阿里云镜像看个人需求(无广告嫌疑)

$ composer config -g repo.packagist composer https://mirrors.aliyun.com/composer

12. 通过 Composer 安装 hyperf 骨架

安装时选择看个人需求哈!

$ composer create-project hyperf/hyperf-skeleton

13. 查看一下配置等信息

一般情况下,hyperf 官方的源镜像都是配置好的
以下只是提供一下命令
查看 swoole

$ php --ri swoole
$ php -i | grep ini

14. php.ini 内写入一下信息

特别注意 Off 中 O 为大写

extension="grpc.so"
extension="redis.so"
extension="swoole.so"
swoole.use_shortname = 'Off'

15. 存在兼容性问题的扩展

  • 由于 Hyperf 基于 Swoole 协程实现
  • 而 Swoole 4 带来的协程功能是 PHP 前所未有的,所以与不少扩展都仍存在兼容性的问题。
  • 以下扩展(包括但不限于)都会造成一定的兼容性问题,不能与之共用或共存:
  • xhprof
  • xdebug
  • blackfire
  • trace
  • uopz

相关推荐