只想更新某个特定的库,不想更新它的所有依赖,很大略
composer update foo/bar
此外,这个技巧还可以用来办理“警告信息问题”。你一定见过这样的警告信息:
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中记载的不同。

那么我们该怎么办呢?update命令可以更新lock文件,但是如果仅仅增加了一些描述,该当是不打算更新任何库。这种情形下,只需update nothing:
$ composer update nothingLoading composer repositories with package informationUpdating dependenciesNothing to install or updateWriting lock fileGenerating autoload files
这样一来,Composer不会更新库,但是会更新composer.lock。把稳nothing并不是update命令的关键字。只是没有nothing 这个包导致的结果。如果你输入foobar,结果也一样。
如果你用的Composer版本足够新,那么你可以直策应用--lock选项:
composer update --lock
2. 不编辑composer.json的情形下安装库
你可能会以为每安装一个库都须要修正composer.json太麻烦,那么你可以直策应用require命令。
composer require "foo/bar:1.0.0"
这个方法也可以用来快速地新开一个项目。init命令有--require选项,可以自动编写composer.json:(把稳我们利用-n,这样就不用回答问题)
$ composer init --require=foo/bar:1.0.0 -n$ cat composer.json{ "require": { "foo/bar": "1.0.0" }}
3. 派生很随意马虎
初始化的时候,你试过create-project命令么?
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引用的压缩包。为了逼迫利用压缩包,而不是克隆源代码,你可以利用install和update的--prefer-dist选项。
下面是一个例子(我利用了--profile选项来显示实行韶光):
$ composer init --require="twig/twig:1." -n --profileMemory usage: 3.94MB (peak: 4.08MB), time: 0s $ composer install --profileLoading composer repositories with package informationInstalling dependencies - Installing twig/twig (v1.12.2) Downloading: 100% Writing lock fileGenerating autoload filesMemory usage: 10.13MB (peak: 12.65MB), time: 4.71s $ rm -rf vendor $ composer install --profileLoading composer repositories with package informationInstalling dependencies from lock file - Installing twig/twig (v1.12.2) Loading from cache Generating autoload filesMemory 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 -vYou have changes in the following dependencies:/path/to/app/vendor/symfony/yaml/Symfony/Component/Yaml: M Dumper.php
当你试图更新一个修正过的库的时候,Composer会提醒你,讯问是否放弃修正:
$ composer updateLoading composer repositories with package informationUpdating 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%的性能丢失。