信息发布→ 登录 注册 退出

composer的 “post-update-cmd” 脚本不执行怎么办

发布时间:2025-10-14

点击量:
先检查post-update-cmd是否正确定义在composer.json的scripts中,确保使用数组格式并全小写键名;确认执行的是composer update而非install,因该钩子仅在update时触发;若在生产环境,应同时定义post-install-cmd;脚本命令建议使用./vendor/bin/artisan等相对路径避免环境问题;通过composer update -vvv查看详细日志,确认脚本是否加载与执行;排除COMPOSER_NO_SCRIPTS=1或--no-scripts导致脚本被禁用的情况。

如果 Composer 的 "post-update-cmd" 脚本没有执行,可能是配置、语法或环境问题。下面列出常见原因和解决方法。

检查脚本是否正确定义

确保 composer.json 中的 scripts 部分正确书写:

{
    "scripts": {
        "post-update-cmd": [
            "echo '更新完成'",
            "php artisan optimize"
        ]
    }
}

注意:

  • 键名必须是 post-update-cmd(全小写)
  • 值可以是字符串或数组,推荐用数组以便执行多条命令
  • 修改后需运行 composer update 才会触发该钩子

确认是否实际执行了 update 命令

post-update-cmd 只在运行 composer update 时触发,不会在 composer install 时执行。

如果你是从 composer.lock 安装依赖(如生产环境部署),应使用 post-install-cmd 或同时定义两个钩子:

"scripts": {
    "post-install-cmd": [
        "echo '安装完成'"
    ],
    "post-update-cmd": [
        "echo '更新完成'"
    ]
}

脚本中命令路径或权限问题

某些命令可能因环境变量或路径问题无法执行。例如:

  • 使用 php artisan,系统可能调用的是全局 php,而非项目所用版本
  • 建议改用 ./vendor/bin/artisan 或完整路径
  • 确保脚本文件有可执行权限(Linux/macOS)

示例:

"post-update-cmd": [
    "./vendor/bin/artisan config:clear",
    "./vendor/bin/artisan route:clear"
]

开启调试查看脚本执行情况

运行命令时加上 -vvv 参数,查看详细输出:

composer update -vvv

输出中会显示是否加载并执行了 scripts,有助于判断是未触发还是命令执行失败。

检查是否被插件或配置禁用

某些 CI 环境或配置可能禁用了脚本执行。确保没有设置:

  • COMPOSER_NO_SCRIPTS=1
  • --no-scripts 参数被传入

这些都会跳过所有脚本,包括 post-update-cmd。

基本上就这些。先确认钩子名称、命令位置和执行条件,再通过 -vvv 查看日志,通常能快速定位问题。

标签:# 字符串  # 是从  # 会在  # 才会  # 键名  # 如果你  # 加载  # 环境问题  # 是否正确  # 而非  # 的是  # php  # cos  # 解决方法  # 环境变量  # macos  # mac  # composer  # json  # js  # linux  
在线客服
服务热线

服务热线

4008888355

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!