搜索
首页开发工具composer谨慎使用composer update!

谨慎使用composer update!

Jul 13, 2020 pm 01:28 PM
composerupdate

下面由composer教程栏目给大家介绍关于谨慎使用composer update的问题,希望对需要的朋友有所帮助!

谨慎使用composer update!

问题说明

我们经常要往现有的项目中添加扩展包,有时候因为文档的错误引导,如下图来自 这个文档 的:

谨慎使用composer update!

composer update 这个命令在我们现在的逻辑中,可能会对项目造成巨大伤害。

因为 composer update 的逻辑是按照 composer.json 指定的扩展包版本规则,把所有扩展包更新到最新版本,注意,是 所有扩展包,举个例子,你在项目一开始的时候使用了 monolog,当时的配置信息是

"monolog/monolog": "1.*",

安装的是 monolog 1.1 版本,而一个多月以后的现在,monolog 已经是 1.2 了,运行命令后直接更新到 1.2,这时项目并没有针对 1.2 进行过测试,项目一下子变得很不稳定,情况有时候会比这个更糟糕,尤其是在一个庞大的项目中,你没有对项目写完整覆盖测试的情况,什么东西坏掉了你都不知道。

那应该使用哪个命令呢?install, update 还是 require ?

接下来我们一一解释。

简单解释

composer install - 如有 composer.lock 文件,直接安装,否则从 composer.json 安装最新扩展包和依赖;
composer update - 从 composer.json 安装最新扩展包和依赖;
composer update vendor/package - 从 composer.json 或者对应包的配置,并更新到最新;
composer require new/package - 添加安装 new/package, 可以指定版本,如: composer require new/package ~2.5.

流程

下来介绍几个日常生产的流程,来方便加深大家的理解。

流程一:新项目流程 
创建 composer.json,并添加依赖到的扩展包; 
运行 composer install,安装扩展包并生成 composer.lock; 
提交 composer.lock 到代码版本控制器中,如:git;

流程二:项目协作者安装现有项目 
克隆项目后,根目录下直接运行 composer install 从 composer.lock 中安装 指定版本 的扩展包以及其依赖;

此流程适用于生产环境代码的部署。

流程三:为项目添加新扩展包

使用 composer require vendor/package 添加扩展包; 
提交更新后的 composer.json 和 composer.lock 到代码版本控制器中,如:git;

关于 composer.lock 文件

composer.lock 文件里保存着对每一个代码依赖的版本记录(见下图),提交到版本控制器中,并配合composer install 使用,保证了团队所有协作者开发环境、线上生产环境中运行的代码版本的一致性。

谨慎使用composer update!

关于扩展包的安装方法

那么,准备添加一个扩展包,install, update, require 三个命令都可以用来安装扩展包,选择哪一个才是正确的呢?

答案是:使用 composer require 命令

另外,在手动修改 composer.json 添加扩展包后,composer update new/package 进行指定扩展包更新的方式,也可以正确的安装,不过不建议使用这种方法,因为,一旦你忘记敲定后面的扩展包名,就会进入万劫不复的状态,别给自己留坑呀。

上面的概念不论对新手或者老手来说,都比较混淆,主要记住这个概念:

原有项目新添加扩展的,都使用 composer require new/package 这种方式来安装。

需要加版本的话

composer require "foo/bar:1.0.0"

更新指定扩展到指定版本

有时候你之前使用过的扩展包,加入了新功能,你想更新单独这个扩展包到指定版本,也可以使用 require 来操作。

如下面例子,需要更新 “sami/sami”: “3.0.” 到 “sami/sami”: “3.2.” 
谨慎使用composer update!

命令行运行: 
谨慎使用composer update! 

以上是谨慎使用composer update!的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:csdn。如有侵权,请联系admin@php.cn删除
作曲家:PHP软件包管理的综合指南作曲家:PHP软件包管理的综合指南May 11, 2025 am 12:17 AM

Composer是一个PHP依赖管理工具,通过composer.json文件管理项目依赖。1.初始化项目使用composerinit。2.添加依赖如composerrequireguzzlehttp/guzzle。3.高级用法包括配置私有仓库和使用脚本钩子。4.常见错误如依赖冲突可通过composerwhy-not命令调试。5.性能优化建议使用composerinstall--prefer-dist和定期更新依赖。

作曲家在行动中:自动化依赖性分辨率作曲家在行动中:自动化依赖性分辨率May 10, 2025 am 12:22 AM

Composer通过自动化依赖解析简化了PHP项目的依赖管理。1)读取composer.json解析依赖需求;2)构建依赖树处理版本冲突;3)从Packagist下载并安装依赖到vendor目录;4)生成composer.lock确保依赖一致性,从而提升开发效率。

AI和作曲家:增强代码质量和开发AI和作曲家:增强代码质量和开发May 09, 2025 am 12:20 AM

AI在Composer中主要通过依赖推荐、依赖冲突解决和代码质量提升来提高开发效率和代码质量。1.AI可以根据项目需求推荐合适的依赖包。2.AI提供智能解决方案来处理依赖冲突。3.AI审查代码并提供优化建议,提升代码质量。通过这些功能,开发者可以更专注于业务逻辑的实现。

什么定义了作曲家:了解角色什么定义了作曲家:了解角色May 08, 2025 am 12:07 AM

作曲家是通过创作音乐作品来表达情感、讲述故事或表达思想的人,他们的角色包括构思音乐结构、选择乐器组合和与其他音乐家合作。1)作曲家在创作过程中会经历构思、创作、修改和完善四个阶段;2)他们需要掌握音乐理论,如和声、对位和旋律,以确保作品的质量和效果。

作曲家:安装,更新和管理依赖项作曲家:安装,更新和管理依赖项May 07, 2025 am 12:07 AM

Composer是PHP的依赖管理工具,通过composer.json和composer.lock文件管理项目依赖。1.安装Composer:运行特定命令并移动composer.phar到系统路径。2.更新Composer:使用composerself-update命令。3.依赖管理:通过composerrequire命令添加依赖,自动更新相关文件并下载包。

AI驱动的作曲家:代码生成和分析AI驱动的作曲家:代码生成和分析May 06, 2025 am 12:11 AM

AI在代码生成和分析中发挥重要作用:1)通过机器学习和NLP生成代码,如GitHub的Copilot;2)进行代码分析,识别bug和优化建议,如SonarQube;3)提高开发效率和代码质量,但需人工审查和优化。

作曲家:AI驱动的工具和集成作曲家:AI驱动的工具和集成May 05, 2025 am 12:11 AM

Composer本身不包含AI功能,但可以通过AI工具增强其能力。1)AI可以分析composer.json文件,建议优化依赖项和预测版本冲突。2)AI驱动的平台如GitHubCopilot可提供实时代码建议,提升开发效率。使用AI工具时需结合实际情况进行验证和调整。

成功作曲家的属性成功作曲家的属性May 04, 2025 am 12:13 AM

成功作曲家的关键特质包括:1)丰富的创意与想象力,2)扎实的技术技能与工具掌握。这些特质与编程中的创造性和结构化思维相似,帮助作曲家在音乐创作中实现创意并优化作品。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器