cyberduck/php-fpm-laravel专为运行基于Laravel的应用程序打造的PHP-FPM容器Docker镜像。
laravel.ini)xdebug.ini)t:运行单元测试(vendor/bin/phpunit),使用docker-compose exec [service_name] td:运行Laravel Dusk浏览器测试(artisan dusk),使用docker-compose exec [service_name] dart:运行Laravel artisan命令fresh:执行数据库迁移刷新并填充种子数据(artisan migrate:fresh --seed)在docker-compose.yml文件中使用镜像时,可指定镜像标签。标签用于区分不同版本的Docker镜像。
8.48.38.28.18.07.47.37.27.17.05.65.4注意:master分支不用于生成镜像,仅用于文档。仅标签/分支用于生成镜像。
ymlversion: '2' services: php-fpm: image: cyberduck/php-fpm-laravel(:<version-tag>) volumes: - ./:/var/www/ - ~/.ssh:/root/.ssh # 可用于composer(如果你使用私有代码仓库) networks: - my_net # 如果你在容器之间使用网络
所有PHP 8.1以上版本的镜像均配置支持xDebug 3。
镜像预装Xdebug但默认禁用。可通过环境变量启用Xdebug,可通过.env文件、docker命令或docker-compose传递环境变量实现。
在.env文件中添加以下内容,然后启动/重启容器:
textXDEBUG=true PHP_IDE_CONFIG="serverName=phpstorm-server" # 仅PhpStorm需要,用于路径映射 REMOTE_HOST="<HOST_IP>" # 若未设置,默认值为'host.docker.internal',适用于OSX和Windows
通过-e选项在run命令中传递所需变量:
bashdocker run -d \ -e XDEBUG=true \ -e PHP_IDE_CONFIG="serverName=phpstorm-server" \ # 仅PhpStorm需要,用于路径映射 -e REMOTE_HOST="<HOSTIP>" \ # 若未设置,默认值为'host.docker.internal',适用于OSX和Windows -v /root/of/project:/var/www \ -v ~/.ssh:/root/.ssh \ cyberduck/php-fpm-laravel(:<version-tag>)
在使用该镜像的服务的environment部分传递变量:
ymlversion: '2' services: php-fpm: image: cyberduck/php-fpm-laravel(:<version-tag>) environment: XDEBUG: true PHP_IDE_CONFIG: "serverName=phpstorm-server" # 仅PhpStorm需要,用于路径映射 REMOTE_HOST: "<HOSTIP>" # 若未设置,默认值为'host.docker.internal',适用于OSX和Windows volumes: - ./:/var/www/ - ~/.ssh:/root/.ssh # 可用于composer(如果你使用私有代码仓库) networks: - my_net # 如果你在容器之间使用网络
要使xDebug与PhpStorm配合使用,需创建服务器。通过Preferences > Languages & Frameworks > PHP > Servers进入,然后按以下步骤操作:
+符号。PHP_IDE_CONFIG="serverName=<CONFIGURED_SERVER_NAME>"。http://localhost,若使用虚拟主机则使用对应主机名,例如http://myapp.localhost。80。Use path mappings复选框。/var/www。要在Visual Studio Code中使用Xdebug,需在项目根目录的.vscode文件夹中添加launch.json文件。以下是launch.json文件示例:
json{ "version": "0.2.0", "configurations": [ { "name": "Listen for XDebug", "type": "php", "request": "launch", "port": 9000, "pathMappings": { "/var/www": "${workspaceFolder}" } } ] }
添加后,导航至调试部分,在左侧BREAKPOINTS部分取消勾选Everything复选框。从顶部下拉菜单选择Listen for XDebug,然后按播放按钮。
现在可通过添加断点并刷新浏览器测试Xdebug。
manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务