0

0

composer如何使用--prefer-dist和--prefer-source_下载模式区别【详解】

尼克

尼克

发布时间:2026-01-11 16:03:20

|

255人浏览过

|

来源于php中文网

原创

Composer 默认优先使用 --prefer-dist 模式,通过 config.preferred-install 配置 {"*": "dist"} 实现;适合生产部署与 CI 构建,速度快、体积小、不依赖 Git;--prefer-source 适用于调试、打补丁或开发分支切换,需克隆完整 Git 仓库。

composer如何使用--prefer-dist和--prefer-source_下载模式区别【详解】

composer install 和 update 默认用什么模式

Composer 默认优先使用 --prefer-dist,只要包在 dist(如 ZIP 归档)和 source(Git 仓库)两种方式都提供,它就会下载预打包的压缩包。这个行为由 config.preferred-install 控制,默认值是 {"*": "dist"}

--prefer-dist 适合哪些场景

它从 Packagist 提供的 CDN 链接下载已构建好的 ZIP/TAR 包,速度快、不依赖 Git、不保留 .git 目录,适合生产环境部署和 CI 构建。

  • 下载体积小(不含历史提交、测试文件、.git 目录)
  • 安装快,尤其网络条件一般时明显优于 source
  • 不会因本地 Git 配置(如 proxy、credential helper)失败而中断
  • 生成的 vendor 目录更“干净”,无法执行 git pullgit log

如果你只是运行项目,不需要改依赖源码,--prefer-dist 是更稳妥的选择。

--prefer-source 什么时候必须用

它会克隆完整的 Git 仓库到 vendor/xxx/xxx,适用于需要调试、打补丁、或开发中频繁切换分支的场景。

社研通
社研通

文科研究生的学术加速器

下载
  • 能直接在 vendor 里改代码、提交、切分支(比如临时 patch 某个 bug)
  • 某些包没发布 dist(例如私有仓库未配置 archive,或 packagist.org 上标记为 "archive": false
  • 你明确需要 .git 目录(例如某些工具依赖 git 插件读取版本信息)
  • 本地 composer.json 中该包用了 "dev-master""dev-feature/xxx" 这类开发版约束时,Composer 通常自动 fallback 到 source
composer require monolog/monolog:dev-main --prefer-source

常见误操作与陷阱

很多人以为加了 --prefer-source 就能“永久保留 Git 状态”,但其实:

  • composer update 仍可能把 source 切回 dist —— 取决于当前包的版本约束是否匹配 dist 发布的 tag
  • 私有 GitLab/GitHub 仓库若未配置 dist URL(如缺少 archive 配置),即使加 --prefer-dist 也会退化为 source
  • composer install --prefer-source 不会覆盖已存在的 dist 安装;得先删掉 vendor 或用 --force-reinstall
  • 某些企业镜像(如腾讯云 TKE Composer 镜像)只缓存 dist,--prefer-source 会绕过镜像直连原始 Git 服务器,可能超时或被墙

真正要锁定 source 模式,得在 composer.json 里写死:

"config": {
  "preferred-install": {"my-private/package": "source"},
  "sort-packages": true
}

dist 和 source 的选择不是“哪个更好”,而是“哪个更符合当前动作的目的”。改依赖就 source,发版就 dist,混用容易导致 vendor 状态不可控。

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

148

2023.12.25

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

408

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

532

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

自建git服务器
自建git服务器

git服务器是目前流行的分布式版本控制系统之一,可以让多人协同开发同一个项目。本专题为大家提供自建git服务器相关的各种文章、以及下载和课程。

637

2023.07.05

git和svn的区别
git和svn的区别

git和svn的区别:1、定义不同;2、模型类型不同;3、存储单元不同;4、是否拥有全局版本号;5、内容完整性不同;6、版本库不同;7、克隆目录速度不同;8、分支不同。php中文网为大家带来了git和svn的相关知识、以及相关文章等内容。

526

2023.07.06

git撤销提交的commit
git撤销提交的commit

Git是一个强大的版本控制系统,它提供了很多功能帮助开发人员有效地管理和控制代码的变更,本专题为大家提供git 撤销提交的commit相关的各种文章内容,供大家免费下载体验。

264

2023.07.24

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

80

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.2万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号