--prefer-dist 优先下载预打包压缩包,速度快、体积小、适合生产环境;--prefer-source 优先克隆完整源码仓库,可调试修改、适合开发维护;二者为偏好而非强制,会依包支持情况自动回退。

两者控制 Composer 安装包时的获取方式:--prefer-dist 优先下载预打包的压缩包(如 zip/tar),--prefer-source 优先克隆源码仓库(如 Git)。
--prefer-dist:快、轻量、适合生产环境
Composer 会从 Packagist 或包作者配置的 dist URL 下载已构建好的归档文件(通常是 zip 或 tar.gz)。这些文件不含版本控制元数据(如 .git 目录)、开发用脚本或测试代码,体积小、解压快、校验可靠(通过 SHA256 签名验证)。
- 默认行为,无需显式指定
- 适合部署、CI/CD、Docker 构建等对速度和体积敏感的场景
- 无法直接修改包内代码(因为没带 .git,也没法切分支或提交)
--prefer-source:可修改、可调试、适合开发维护
Composer 会执行 git clone(或其他 VCS 命令)拉取完整源码仓库,保留 .git 目录、所有分支、标签和提交历史。
- 方便你临时 patch 第三方包、调试底层逻辑、或向包贡献 PR
- 能用 git checkout 切换版本、git diff 查看变更、甚至 git commit 提交本地修改(但注意:下次 install 可能被覆盖)
- 耗时更长,占用更多磁盘空间,且依赖网络和 Git 可用性
它们不是互斥开关,而是“偏好”而非强制
Composer 会按需回退:比如某包只提供了 dist,没配 source 信息,即使加了 --prefer-source,也会退回到下载 dist;反之,若包禁用了 dist(只允许 source),--prefer-dist 也会失效。
- 可通过 composer show vendor/package 查看该包是否同时支持 dist 和 source
- 项目根目录的 composer.json 中 "prefer-stable": true 不影响此选项,二者无关
- 全局设置?没有。只能每次命令加参数,或在 config 中设 "preferred-install": {"*": "dist"} 来统一默认行为
基本上就这些。选哪个,取决于你此刻是要跑起来,还是准备钻进去改一改。










