0

0

如何解决ComposerVendor目录臃肿问题,使用liborm85/composer-vendor-cleaner让你的项目更轻盈

聖光之護

聖光之護

发布时间:2025-11-12 21:38:01

|

523人浏览过

|

来源于php中文网

原创

如何解决composervendor目录臃肿问题,使用liborm85/composer-vendor-cleaner让你的项目更轻盈

最近在处理一个大型PHP项目的部署工作时,我遇到了一个让人头疼的问题:每次部署,光是上传 vendor 目录就要花费大量时间。这个目录动辄几百兆甚至上G,里面包含了各种第三方库的测试文件、文档、示例代码、.git 目录、.travis.yml 配置等等,这些东西在生产环境中根本用不到,却白白占用了服务器空间,拖慢了部署速度。

我尝试过一些土办法,比如在部署后手动删除 vendor 目录下的 testsdocs 等文件夹,但这不仅效率低下,而且很容易遗漏或者误删,导致程序出现意想不到的问题。尤其是在CI/CD流程中,这种手动干预的方式更是不可取。我急需一个自动化、可靠的解决方案。

Composer在线学习地址:学习地址

幸运的是,PHP社区总有大神出手相助!经过一番搜索,我发现了 liborm85/composer-vendor-cleaner 这个Composer插件,它简直是为解决我的痛点而生。

告别臃肿:liborm85/composer-vendor-cleaner 登场

liborm85/composer-vendor-cleaner 是一个Composer插件,它的核心功能是在 composer installcomposer update 之后,自动扫描并清理 vendor 目录中那些你指定为“不必要”的文件和文件夹。它通过高度灵活的配置,让你能够精确控制哪些内容应该被移除,从而在不影响项目功能的前提下,大幅减小 vendor 目录的体积。

如何使用它让项目“瘦身”?

使用 liborm85/composer-vendor-cleaner 非常简单,主要分为安装和配置两步。

1. 安装插件

你可以选择将其安装到你的项目本地,或者全局安装。对于大多数项目,推荐本地安装,这样配置会随着项目一起管理:

composer require liborm85/composer-vendor-cleaner

如果你希望在所有项目中使用相同的清理规则,可以考虑全局安装:

uBrand
uBrand

一站式AI品牌创建平台,在线品牌设计,AI品牌策划,智能品牌营销;uBrand帮助创业者轻松打造个性品牌!

下载
composer global require liborm85/composer-vendor-cleaner

2. 配置清理规则

插件安装完成后,你需要在项目的 composer.json 文件中添加 extra.dev-files 配置项,来定义你想要清理的文件和目录。这个配置项支持强大的Glob模式匹配,让你能够非常精细地控制清理范围。

以下是一个配置示例,展示了其灵活性:

{
    "require": {
        "liborm85/composer-vendor-cleaner": "^1.0"
    },
    "extra": {
        "dev-files": {
            "/": [                  // 匹配所有库包的根目录和bin目录
                "tests/",           // 移除所有测试目录
                "docs/",            // 移除所有文档目录
                ".travis.yml",      // 移除所有.travis.yml文件
                ".github/"          // 移除所有.github目录
            ],
            "*/*": [                // 匹配所有库包目录(不包括bin目录)
                "*.sh",             // 移除所有shell脚本文件
                "CONTRIBUTING.md"   // 移除贡献指南文件
            ],
            "twig/twig": [          // 仅匹配 twig/twig 包
                "doc/",             // 移除其doc目录
                "/drupal_test.sh"   // 移除其根目录下的drupal_test.sh文件
            ],
            "symfony/*": [          // 匹配所有symfony开头的包
                "Tests/"            // 移除其Tests目录
            ],
            "example/package": [    // 匹配 example/package 包
                "languages/*",      // 移除languages目录下的所有文件和目录
                "!languages/cs.php" // 但排除languages/cs.php文件
            ]
        }
    },
    "config": {
        "dev-files": {
            "match-case": true,         // 是否区分文件名大小写,默认为true
            "remove-empty-dirs": true,  // 是否移除清理后留下的空目录,默认为true
            "no-dev-only": false        // 如果设置为true,则只在运行`composer install --no-dev`时才进行清理
        }
    }
}

配置详解:

  • *键名("/", `"/","twig/twig","symfony/"` 等)**:这些是匹配目标路径的规则。
    • "/":表示匹配 vendor 目录下所有直接子目录(即所有第三方包的根目录)以及 bin 目录。
    • "*/*":表示匹配 vendor 目录下所有第三方包的根目录,但不包括 bin 目录。
    • "twig/twig":精确匹配 vendor/twig/twig 这个特定包。
    • "symfony/*":使用通配符匹配所有以 symfony/ 开头的包,例如 symfony/consolesymfony/http-kernel 等。
  • 值(数组):数组中的每个字符串都是一个Glob模式,用于匹配要删除的文件或目录。
    • tests/:匹配名为 tests 的目录。
    • *.sh:匹配所有以 .sh 结尾的文件。
    • !languages/cs.php:感叹号 ! 表示排除规则,即 languages 目录下的所有内容都会被删除,除了 cs.php 文件。
  • config.dev-files:提供了一些额外的全局配置选项,可以进一步微调清理行为。
    • match-case: 是否区分文件名大小写,默认 true
    • remove-empty-dirs: 清理后是否删除空目录,默认 true
    • no-dev-only: 如果设置为 true,则只有当Composer命令带上 --no-dev 参数时(通常用于生产环境部署)才会执行清理。这非常有用,可以在开发环境中保留所有文件,而在生产环境自动清理。

你甚至可以将这些清理规则定义在一个独立的JSON文件中(例如 composer.dev-files.json),然后在 composer.json 中引用它:

{
    "extra": {
        "dev-files": "composer.dev-files.json"
    }
}

优势与实际应用效果

引入 liborm85/composer-vendor-cleaner 后,我的项目部署流程发生了质的飞跃:

  1. 显著减小部署包体积:清理掉几百兆甚至上G的无用文件后,部署包的大小可以减少一半甚至更多,极大地节省了存储空间和网络传输带宽。
  2. 加速部署时间:文件传输量的减少直接带来了部署时间的缩短,尤其是在网络条件不佳或需要频繁部署的环境下,效果非常明显。
  3. 更纯净的生产环境:生产服务器上不再有与生产无关的测试、文档等文件,减少了潜在的安全风险和混乱。
  4. 自动化与可靠性:一旦配置完成,清理过程完全自动化,无需人工干预,避免了手动清理可能带来的错误和遗漏。
  5. 高度可定制:灵活的Glob模式和排除规则,让我可以根据每个项目的具体需求,精确控制清理范围,确保不会误删任何必要文件。
  6. 与CI/CD无缝集成:在自动化部署流程中,这个插件能完美融入,成为部署流水线中不可或缺的一环。

如果你也曾被臃肿的 vendor 目录困扰,那么 liborm85/composer-vendor-cleaner 绝对值得一试。它不仅能让你的项目更轻盈,还能让你的部署工作变得前所未有的顺畅和高效。赶快尝试一下,让你的PHP项目焕发新生吧!

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
PHP Symfony框架
PHP Symfony框架

本专题专注于PHP主流框架Symfony的学习与应用,系统讲解路由与控制器、依赖注入、ORM数据操作、模板引擎、表单与验证、安全认证及API开发等核心内容。通过企业管理系统、内容管理平台与电商后台等实战案例,帮助学员全面掌握Symfony在企业级应用开发中的实践技能。

78

2025.09.11

composer是什么插件
composer是什么插件

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

155

2023.12.25

json数据格式
json数据格式

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

420

2023.08.07

json是什么
json是什么

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

536

2023.08.23

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

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

312

2023.10.13

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

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

77

2025.09.10

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

30

2026.01.31

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
第二十四期_PHP8编程
第二十四期_PHP8编程

共86课时 | 3.4万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.5万人学习

第二十三期_PHP编程
第二十三期_PHP编程

共93课时 | 7万人学习

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

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