5 个 Composer 小技巧

Composer是新一代的PHP依赖管理工具。其介绍和基本用法能够看这篇《Composer PHP依赖管理的新时代》。本文介绍使用Composer的五个小技巧,但愿能给你的PHP开发带来方便。javascript

1. 仅更新单个库

只想更新某个特定的库,不想更新它的全部依赖,很简单:php

composer update foo/bar 

此外,这个技巧还能够用来解决“警告信息问题”。你必定见过这样的警告信息:java

Warning: The lock file is not up to date with the latest changes in composer.json, you may be getting outdated dependencies, run update to update them. 

擦,哪里出问题了?别惊慌!若是你编辑了composer.json,你应该会看到这样的信息。好比,若是你增长或更新了细节信息,好比库的描述、做者、更多参数,甚至仅仅增长了一个空格,都会改变文件的md5sum。而后Composer就会警告你哈希值和composer.lock中记载的不一样。git

那么咱们该怎么办呢?update命令能够更新lock文件,可是若是仅仅增长了一些描述,应该是不打算更新任何库。这种状况下,只需update nothingsql

$ composer update nothing Loading composer repositories with package information Updating dependencies Nothing to install or update Writing lock file Generating autoload files 

这样一来,Composer不会更新库,可是会更新composer.lock。注意nothing并非update命令的关键字。只是没有nothing 这个包致使的结果。若是你输入foobar,结果也同样。json

若是你用的Composer版本足够新,那么你能够直接使用--lock选项:segmentfault

composer update --lock 

2. 不编辑composer.json的状况下安装库

你可能会以为每安装一个库都须要修改composer.json太麻烦,那么你能够直接使用require命令。缓存

composer require "foo/bar:1.0.0"

这个方法也能够用来快速地新开一个项目。init命令有--require选项,能够自动编写composer.json:(注意咱们使用-n,这样就不用回答问题)ruby

$ composer init --require=foo/bar:1.0.0 -n $ cat composer.json {     "require": {         "foo/bar": "1.0.0"     } }

3. 派生很容易

初始化的时候,你试过create-project命令么?app

composer create-project doctrine/orm path 2.2.0 

这会自动克隆仓库,并检出指定的版本。克隆库的时候用这个命令很方便,不须要搜寻原始的URI了。

4. 考虑缓存,dist包优先

最近一年以来的Composer会自动存档你下载的dist包。默认设置下,dist包用于加了tag的版本,例如"symfony/symfony": "v2.1.4",或者是通配符或版本区间,"2.1.*"">=2.2,<2.3-dev"(若是你使用stable做为你的minimum-stability

dist包也能够用于诸如dev-master之类的分支,Github容许你下载某个git引用的压缩包。为了强制使用压缩包,而不是克隆源代码,你能够使用installupdate--prefer-dist选项。

下面是一个例子(我使用了--profile选项来显示执行时间):

$ composer init --require="twig/twig:1.*" -n --profile Memory usage: 3.94MB (peak: 4.08MB), time: 0s  $ composer install --profile Loading composer repositories with package information Installing dependencies - Installing twig/twig (v1.12.2) Downloading: 100% Writing lock file Generating autoload files Memory usage: 10.13MB (peak: 12.65MB), time: 4.71s $ rm -rf vendor $ composer install --profile Loading composer repositories with package information Installing dependencies from lock file - Installing twig/twig (v1.12.2) Loading from cache Generating autoload files Memory usage: 4.96MB (peak: 5.57MB), time: 0.45s 

这里,twig/twig:1.12.2的压缩包被保存在~/.composer/cache/files/twig/twig/1.12.2.0-v1.12.2.zip。从新安装包时直接使用。

5. 考虑修改,源代码优先

当你须要修改库的时候,克隆源代码就比下载包方便了。你能够使用--prefer-source来强制选择克隆源代码。

composer update symfony/yaml --prefer-source 

接下来你能够修改文件:

composer status -v You have changes in the following dependencies: /path/to/app/vendor/symfony/yaml/Symfony/Component/Yaml:     M Dumper.php

当你试图更新一个修改过的库的时候,Composer会提醒你,询问是否放弃修改:

$ composer update Loading composer repositories with package information Updating dependencies   - Updating symfony/symfony v2.2.0 (v2.2.0- => v2.2.0)     The package has modified files:     M Dumper.php     Discard changes [y,n,v,s,?]?

为生产环境做准备

最后提醒一下,在部署代码到生产环境的时候,别忘了优化一下自动加载:

composer dump-autoload --optimize

安装包的时候能够一样使用--optimize-autoloader。不加这一选项,你可能会发现20%到25%的性能损失

若是你须要帮助,或者想要了解某个命令的细节,你能够阅读官方文档,或者查看JoliCode作的这个交互式备忘单

相关文章
相关标签/搜索