文章中使用的软件:

  • Mac:11.4(macOS Big Sur) ,处理器为:Intel Core。
  • Docker:3.3.3

php_1.png

目标

  • 支持 PHP 5.6.x 环境
  • 支持 PHP 7.2.x 环境

下载

Docker 软件下载安装,不做过多解释,一步步安装即可。

下载地址:https://www.docker.com/products/docker-desktop

代理设置

  1. "registry-mirrors" : [
  2. "http://registry.docker-cn.com",
  3. "http://hub-mirror.c.163.com"
  4. ],

php_2.png

配置环境

PHP 7.2.x,占用本地端口 8081

  1. 启动 docker;
  2. 下载压缩包:php7-2-x.zip 并进行解压;
  3. 进入到 php7-2-x 目录,直接运行 docker-compose up 即可;
  4. 浏览器输入:http://127.0.0.1:8081/;

php_3.png

PHP 5.6.x,占用本地端口 8082

  1. 启动 docker;
  2. 下载压缩包:php5-6-x.zip 并进行解压;
  3. 进入到 php5-6-x 目录,直接运行 docker-compose up 即可;
  4. 浏览器输入:http://127.0.0.1:8082/;

php_4.png

端口映射

local.php72.com -> 127.0.0.1:8081

因为在 /etc/hosts 文件中不能做端口映射,需要借助其他工具。

我借助的工具为 Chrome 浏览器插件:Simple Proxy

下载方式:

  • Chrome 应用商店下载,搜索 Simple Proxy
  • 加载本地扩展程序,下载地址:chrome-simply-proxy

看下安装好界面:

php_5.png

配置成功后,访问 http://local.php72.com/

php_3.png

local.php56.com -> 127.0.0.1:8082

同上。

备注

docker-compose 相关命令

  • docker-compose up 构建容器 参数[-d]为后台运行
  • docker-compose start 启用容器
  • docker-compose stop 停止容器
  • docker-compose restart 重启容器
  • docker-compose down 删除容器
  • docker-compose ps 查看当前容器状态

php7-2-x 目录介绍

  1. .
  2. ├── docker-compose.yml
  3. ├── log
  4. └── nginx
  5. └── local.php72.com_access.log
  6. ├── phpdocker
  7. ├── README.html
  8. ├── README.md
  9. ├── nginx
  10. └── default.conf
  11. └── php-fpm
  12. ├── Dockerfile
  13. └── php-ini-overrides.ini
  14. └── web
  15. └── phpinfo
  16. └── index.php

1、docker-compose.yml,容器编排的配置文件,文件无需更改。

  1. version: "3.1"
  2. services:
  3. webserver:
  4. image: nginx:alpine
  5. container_name: php7-2-x-webserver
  6. working_dir: /application
  7. volumes:
  8. - .:/application
  9. - ./phpdocker/nginx:/etc/nginx/conf.d
  10. ports:
  11. - "8081:80"
  12. php-fpm:
  13. build: phpdocker/php-fpm
  14. container_name: php7-2-x-php-fpm
  15. working_dir: /application
  16. volumes:
  17. - .:/application
  18. - ./phpdocker/php-fpm/php-ini-overrides.ini:/etc/php/7.2/fpm/conf.d/99-overrides.ini

2、log/nginx 为日志目录,包含 _access.log 和 _php_errors.log,* 为配置的虚拟域名。

3、phpdocker/nginx 为虚拟域名配置目录,其中 default.conf 配置的虚拟域名为 local.php72.com,不过多解释,大家一看就懂,其他目录和文件无需调整。

  1. server {
  2. listen 80;
  3. server_name local.php72.com;
  4. client_max_body_size 108M;
  5. access_log /application/log/nginx/${server_name}_access.log;
  6. root /application/web/phpinfo;
  7. index index.php;
  8. # try to serve file directly, fallback to index.php
  9. location / {
  10. try_files $uri /index.php$is_args$args;
  11. }
  12. if (!-e $request_filename) {
  13. rewrite ^.*$ /index.php last;
  14. }
  15. location ~ \.php$ {
  16. fastcgi_pass php-fpm:9000;
  17. fastcgi_index index.php;
  18. fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
  19. fastcgi_param PHP_VALUE "error_log=/application/log/nginx/${server_name}_php_errors.log";
  20. fastcgi_buffers 16 16k;
  21. fastcgi_buffer_size 32k;
  22. include fastcgi_params;
  23. }
  24. }

4、web 为代码仓库目录,其中 phpinfo 为域名 local.php72.com 指向的代码目录。

如果想要新增虚拟域名(local.abc.com)配置时,只需 3 步:

  1. 将代码文件夹 abc 放到 web 目录下;
  2. 新增文件 local.abc.com.conf,在配置文件中将代码目录指向到 abc 目录;
  3. 重启容器 docker-compose restart;

php5-6-x 目录介绍

同上。

zip 文件如何生成的?

大家可能会有疑问,zip 文件如何生成的,如果我想搭建其他版本的环境怎么办?

这些文件是在线生成的,网址:https://phpdocker.io/generator

php_6.png

支持的 PHP 版本有:5.6.x7.0.x7.1.x7.2.x7.3.x7.4.x 等。

同时还支持 MySQLMariaDBElasticsearch 等。

按需选择后,点击 Generate project archive 即可生成压缩包。

上面的 php5-6-x.zip 和 php7-2-x.zip 就是这种方式生成的,仅仅是对其进行微调,比如配置 log 目录,web 目录等。

更多功能,大家去探索吧。

下载文章中用到的 zip 文件,请在「新亮笔记」公众号内回复:phpdocker 即可。