
neatous/phpstanPhpstan是一款功能强大的PHP静态代码分析工具,能够在不运行代码的情况下检测潜在错误。本Docker镜像封装了Phpstan的完整运行环境,提供开箱即用的PHP代码静态分析能力,适用于各类PHP项目的代码质量保障流程,无需在本地环境安装Phpstan及依赖。
通过挂载项目目录并指定分析路径执行基础分析:
bashdocker run --rm -v $(pwd):/app phpstan/phpstan analyze /app/src
bashdocker run --rm -v $(pwd):/app phpstan/phpstan analyze /app/src --level=5
项目根目录创建phpstan.neon或phpstan.neon.dist配置文件后:
bashdocker run --rm -v $(pwd):/app phpstan/phpstan analyze /app/src --configuration=/app/phpstan.neon
neonparameters: level: 5 paths: - src/ - tests/ excludePaths: - src/legacy/ checkMissingIterableValueType: true reportUnmatchedIgnoredErrors: true ignoreErrors: - '#Call to an undefined method .*#'
通过临时安装扩展并执行分析:
bashdocker run --rm -v $(pwd):/app -v $(pwd)/composer.json:/tmp/composer.json phpstan/phpstan \ sh -c "composer require --working-dir=/tmp phpstan/phpstan-laravel && \ phpstan analyze /app/src --configuration=/app/phpstan.neon"
yamlname: PHP Static Analysis on: [push, pull_request] jobs: phpstan: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - name: Run Phpstan run: | docker run --rm -v ${{ github.workspace }}:/app phpstan/phpstan \ analyze /app/src --level=5 --no-progress
为加速分析,可挂载缓存目录:
bashdocker run --rm \ -v $(pwd):/app \ -v phpstan-cache:/tmp/phpstan \ phpstan/phpstan analyze /app/src --level=5
| 环境变量 | 默认值 | 说明 |
|---|---|---|
| PHPSTAN_MEMORY_LIMIT | 1G | 分析过程的内存限制 |
| PHPSTAN_PROGRESS | true | 是否显示进度条(CI环境建议设为false) |
| PHP_VERSION | 8.2 | 指定PHP运行版本(部分镜像标签支持) |
latest:最新稳定版本,基于最新PHP版本1.10:特定Phpstan版本(如1.10.x系列)1.10-php8.1:特定Phpstan版本+PHP版本组合nightly:开发版,包含最新特性(不建议生产环境使用)





manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务