摘要:建議使用折音號操作符。對于使用作為版本號標(biāo)準(zhǔn)的項目來說,這種版本約束方式很實用。折音號操作符的行為跟有比較大的關(guān)聯(lián),它允許升級版本到安全的版本。
這篇文章主要介紹一些常用的包管理命令以及包的版本如何進(jìn)行約束。
常用命令 require命令在《Composer快速入門》中已經(jīng)簡單介紹過使用install命令安裝依賴的方式。除了install命令,我們還可以使用require命令快速的安裝一個依賴而不需要手動在composer.json里添加依賴信息:
$ composer require monolog/monolog Using version ^1.19 for monolog/monolog ./composer.json has been updated Loading composer repositories with package information Updating dependencies (including require-dev) - Installing psr/log (1.0.0) Downloading: 100% - Installing monolog/monolog (1.19.0) Downloading: 100% monolog/monolog suggests installing graylog2/gelf-php (Allow sending log messages to a GrayLog2 server) ...... monolog/monolog suggests installing php-console/php-console (Allow sending log messages to Google Chrome) Writing lock file Generating autoload files
Composer會先找到合適的版本,然后更新composer.json文件,在require那添加monolog/monolog包的相關(guān)信息,再把相關(guān)的依賴下載下來進(jìn)行安裝,最后更新composer.lock文件并生成php的自動加載文件。
update命令通過update命令,可以更新項目里所有的包,或者指定的某些包。
# 更新所有依賴 $ composer update # 更新指定的包 $ composer update monolog/monolog # 更新指定的多個包 $ composer update monolog/monolog symfony/dependency-injection # 還可以通過通配符匹配包 $ composer update monolog/monolog symfony/*
需要注意的時,包能升級的版本會受到版本約束的約束,包不會升級到超出約束的版本的范圍。例如如果composer.json里包的版本約束為^1.10,而最新版本為2.0。那么update命令是不能把包升級到2.0版本的,只能最高升級到1.x版本。關(guān)于版本約束請看后面的介紹。
remove命令使用remove命令可以移除一個包及其依賴(在依賴沒有被其他包使用的情況下):
$ composer remove monolog/monolog Loading composer repositories with package information Updating dependencies (including require-dev) - Removing monolog/monolog (1.19.0) - Removing psr/log (1.0.0) Writing lock file Generating autoload filessearch命令
使用search命令可以進(jìn)行包的搜索:
$ composer search monolog monolog/monolog Sends your logs to files, sockets, inboxes, databases and various web services # 如果只是想匹配名稱可以使用--only-name選項 $ composer search --only-name monologshow命令
使用show命令可以列出項目目前所安裝的包的信息:
# 列出所有已經(jīng)安裝的包 $ composer show # 可以通過通配符進(jìn)行篩選 $ composer show monolog/* # 顯示具體某個包的信息 $ composer show monolog/monolog版本約束
前面說到,我們可以指定要下載的包的版本。例如我們想要下載版本1.19的monolog。我們可以通過composer.json文件:
{ "require": { "monolog/monolog": "1.19" } }
然后運行install命令,或者通過require命令達(dá)到目的:
$ composer require monolog/monolog:1.19 # 或者 $ composer require monolog/monolog=1.19 # 或者 $composer require monolog/monolog 1.19
除了像上面那樣指定具體的版本,我們還可以通過不同的約束方式去指定版本。
基本約束 精確版本可以指定具體的版本,告訴Composer只能安裝這個版本。但是如果其他的依賴需要用到其他的版本,則包的安裝或者更新最后會失敗并終止。
例子:1.0.2
范圍使用比較操作符你可以指定包的范圍。這些操作符包括:>,>=,<,<=,!=。
你可以定義多個范圍,使用空格 或者逗號,表示邏輯上的與,使用雙豎線||表示邏輯上的或。其中與的優(yōu)先級會大于或。
需要注意的是,使用沒有邊界的范圍有可能會導(dǎo)致安裝不可預(yù)知的版本,并破壞向下的兼容性。建議使用折音號操作符。
例子:
>=1.0
>=1.0 <2.0
>=1.0 <1.1 || >=1.2
范圍(使用連字符)帶連字符的范圍表明了包含的版本范圍,意味著肯定是有邊界的。其中連字符的左邊表明了>=的版本,而連字符的右邊情況則稍微有點復(fù)雜。如果右邊的版本不是完整的版本號,則會被使用通配符進(jìn)行補全。例如1.0 - 2.0等同于>=1.0.0 <2.1(2.0相當(dāng)于2.0.*),而1.0.0 - 2.1.0則等同于>=1.0.0 <=2.1.0。
例子:1.0 - 2.0
通配符可以使用通配符去定義版本。1.0.*相當(dāng)于>=1.0 <1.1。
例子:1.0.*
下一個重要版本操作符 波浪號~我們先通過后面這個例子去解釋~操作符的用法:~1.2相當(dāng)于>=1.2 <2.0.0,而~1.2.3相當(dāng)于>=1.2.3 <1.3.0。對于使用Semantic Versioning作為版本號標(biāo)準(zhǔn)的項目來說,這種版本約束方式很實用。例如~1.2定義了最小的小版本號,然后你可以升級2.0以下的任何版本而不會出問題,因為按照Semantic Versioning的版本定義,小版本的升級不應(yīng)該有兼容性的問題。簡單來說,~定義了最小的版本,并且允許版本的最后一位版本號進(jìn)行升級(沒懂得話,請再看一邊前面的例子)。
例子:~1.2
折音號^需要注意的是,如果~作用在主版本號上,例如~1,按照上面的說法,Composer可以安裝版本1以后的主版本,但是事實上是~1會被當(dāng)作~1.0對待,只能增加小版本,不能增加主版本。
^操作符的行為跟Semantic Versioning有比較大的關(guān)聯(lián),它允許升級版本到安全的版本。例如,^1.2.3相當(dāng)于>=1.2.3 <2.0.0,因為在2.0版本前的版本應(yīng)該都沒有兼容性的問題。而對于1.0之前的版本,這種約束方式也考慮到了安全問題,例如^0.3會被當(dāng)作>=0.3.0 <0.4.0對待。
例子:^1.2.3
版本穩(wěn)定性如果你沒有顯式的指定版本的穩(wěn)定性,Composer會根據(jù)使用的操作符,默認(rèn)在內(nèi)部指定為-dev或者-stable。例如:
約束 | 內(nèi)部約束 |
---|---|
1.2.3 | =1.2.3.0-stable |
>1.2 | >1.2.0.0-stable |
>=1.2 | >=1.2.0.0-dev |
>=1.2-stable | >=1.2.0.0-stable |
<1.3 | <1.3.0.0-dev |
<=1.3 | <=1.3.0.0-stable |
1 - 2 | >=1.0.0.0-dev <3.0.0.0-dev |
~1.3 | >=1.3.0.0-dev <2.0.0.0-dev |
1.4.* | >=1.4.0.0-dev <1.5.0.0-dev |
如果你想指定版本只要穩(wěn)定版本,你可以在版本后面添加后綴-stable。
minimum-stability 配置項定義了包在選擇版本時對穩(wěn)定性的選擇的默認(rèn)行為。默認(rèn)是stable。它的值如下(按照穩(wěn)定性排序):dev,alpha,beta,RC和stable。除了修改這個配置去修改這個默認(rèn)行為,我們還可以通過穩(wěn)定性標(biāo)識(例如@stable和@dev)來安裝一個相比于默認(rèn)配置不同穩(wěn)定性的版本。例如:
{ "require": { "monolog/monolog": "1.0.*@beta", "acme/foo": "@dev" } }參考
https://getcomposer.org/doc/03-cli.md[2]
https://getcomposer.org/doc/articles/versions.md[3]
http://semver.org/[1]
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/21768.html
摘要:自動代碼擴展開發(fā)時遵守的代碼風(fēng)格是項目開發(fā)規(guī)范。遵照此規(guī)范,在實際操作中,有許多重復(fù),接下來推薦一款專為此規(guī)范量身定制的代碼生成器。可以利用此擴展來快速構(gòu)建項目原型。后續(xù)還會為大家?guī)硪恍┳钚碌募夹g(shù)擴展。 whoops 錯誤提示擴展 whoops 是一個非常優(yōu)秀的 PHP Debug 擴展,它能夠使你在開發(fā)中快速定位出錯的位置。laravel默認(rèn)安裝。showImg(https://s...
摘要:自動代碼擴展開發(fā)時遵守的代碼風(fēng)格是項目開發(fā)規(guī)范。遵照此規(guī)范,在實際操作中,有許多重復(fù),接下來推薦一款專為此規(guī)范量身定制的代碼生成器。可以利用此擴展來快速構(gòu)建項目原型。后續(xù)還會為大家?guī)硪恍┳钚碌募夹g(shù)擴展。 whoops 錯誤提示擴展 whoops 是一個非常優(yōu)秀的 PHP Debug 擴展,它能夠使你在開發(fā)中快速定位出錯的位置。laravel默認(rèn)安裝。showImg(https://s...
摘要:創(chuàng)建帳號提供的是持續(xù)集成服務(wù),簡稱。在這里引入的原因是我們的項目需要使用服務(wù)進(jìn)行持續(xù)集成和測試,當(dāng)然你也可以替換成別的單元測試工具。創(chuàng)建單元測試用例是單元測試類庫家族中的一員,使用的一個主要目的是為我們的模塊創(chuàng)建單元測試用例。 本文首發(fā)于 Travis CI 持續(xù)集成服務(wù)構(gòu)建 Composer 類庫簡明教程,轉(zhuǎn)載請注明出處! 在項目開發(fā)過程中,編碼工作只是軟件開發(fā)整個過程中的一小部分環(huán)...
摘要:以實現(xiàn)自己熟悉的東西為導(dǎo)向比如我們做后端開發(fā),首先是常用的循環(huán)迭代條件判斷增刪改成。它是由實現(xiàn)的,不保證元素的順序,也就是說所說元素插入的順序與輸出的順序不一致。 下面是我直播的文字版,直播地址:https://segmentfault.com/l/15...代碼:https://github.com/zhoumengka...整個項目我們我又細(xì)分了6個版本來演進(jìn),希望更加便于大家對比...
閱讀 2699·2023-04-25 17:21
閱讀 2563·2021-11-23 09:51
閱讀 2856·2021-09-24 10:32
閱讀 3782·2021-09-23 11:33
閱讀 1981·2019-08-30 15:44
閱讀 3461·2019-08-30 11:18
閱讀 3535·2019-08-30 10:53
閱讀 632·2019-08-26 13:25