laravel/framework “symfony/http-kernel”: “~3.3”,
symfony/http-kernel(3.3.13版本) “symfony/translation”: “~2.8|~3.0”,
symfony/http-kernel(3.4版本) “symfony/translation”: “~2.8|~3.0|~4.0”,

symfony/translation3.4版本:

public function __construct($locale, $formatter = null, $cacheDir = null, $debug = false)

而在4.0的時候加入了7.1的特性

 public function __construct(?string $locale, MessageFormatterInterface $formatter = null, string $cacheDir = null, bool $debug = false)

我機器上的版本是PHP 7.0。所以導致了在composer升級的時候symfony/http-kernel也升級,帶來了symfony/translation升級到4.x,引入了PHP7.1的新特性。

解決方法

升級線上機器PHP版本是不可能的事情。于是我只能強制限定版本號。

直接在最上層我的項目中require symfony/translation,并且指定版本號。

"symfony/translation" : "3.3.13"

重新composer update 就可以了。

思考

這是一個典型的依賴包升級導致的業務應用出錯的案例。symfony/translation 從 3.3.13 升級到4.*,需要的PHP版本從7.0升級到7.1。這樣的升級,laravel/framework 版本 v5.5.21 是無感知的。

而我們看 laravel/framework v5.5.21 的(comopser.json)[https://github.com/laravel/framework/blob/v5.5.21/composer.json]

{
 "name": "laravel/framework",
 "description": "The Laravel Framework.",
 ...
 "require": {
 "php": ">=7.0",
 "ext-mbstring": "*",
 "ext-openssl": "*",
 ...
 "symfony/http-kernel": "~3.3",
 },
 ...
}

這里的 PHP >= 7.0 是不是格外扎眼,根本已經不靠譜了。

真正解決辦法

哈,其實這里并沒有結束。這個問題包版本依賴其實各個包都沒有問題。

其實這里有一個問題,我打包機器的PHP版本是7.1,但是線上機器是7.0.0,所以會導致這個問題。

其實composer比我們想象的更為強大。它會根據你當前機器的PHP版本,判斷你的所有依賴分別使用什么版本,在composer update的時候,會根據所有依賴的版本需求選擇一個最好的版本。

所以我把我的打包機器上的PHP切換成7.0,查看生成的composer.lock,里面的symfony/translation就限制到使用3.3.x版本 就不會出現這個問題了。

composer的正確使用姿勢

是否要將composer.lock加入到git庫

這個是我這次犯的一個錯誤,沒有將composer.lock進入版本庫,打包機器composer install的時候就相當于update操作了。對于業務來說,這個是不對的。業務要做的事情是保證業務穩定性,其實任何的庫依賴的升級,都需要經過業務的測試和驗證才能上線。所以,這里強烈建議在業務項目里面,將composer.lock強制加入git代碼庫中。

是否要使用自動升級

版本依賴的時候,使用~,^符號會在composer udpate的時候根據依賴包已經有的類庫。

我理解自動升級的機制有好也有壞處,這個就相當于把主動權(這里已經說的是update的主動權)放在哪里。作為一個基礎類庫,我當然希望你使用我的時候能相信我,我的每次版本升級都是兼容的,也不會引入bug。所以類庫是會希望你會使用自動升級。這樣我的一些bug修復,在你update的時候你就會自動下載并且修復了。

但是對于業務來說,業務穩定是死要求。一旦我update的時候,我使用了你的新下載的包,這個實際上就有可能引入一個bug。沒有經過完整的測試,是不應該做這種操作的。

但是實際上,我們是無法完全杜絕這個情況,比如你的一個lib包依賴了另外一個lib包的時候,它如果使用了自動升級,你是完全沒有辦法的。

所以一旦我們使用包依賴,自動升級的事情,是無法杜絕的。

慎用update

使用update操作的時候,必須想到會引發什么操作,盡量將composer.lock做下差異比對,明白下前后兩個依賴包差別在哪里。

總結

包依賴問題,不僅php有,golang也有,基本注意點都是如上,一樣的。

贊(16)
聲明:本網站發布的內容(圖片、視頻和文字)以原創、轉載和分享網絡內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。郵箱:3140448839@qq.com。本站原創內容未經允許不得轉載,或轉載時需注明出處:三五互聯知識庫 » 一次因composer錯誤使用引發的問題與解決

登錄

找回密碼

注冊

主站蜘蛛池模板: 无码国产精品一区二区VR老人| 亚洲综合伊人久久综合| 国产日韩久久免费影院| 色综合色综合色综合频道| 日韩美女亚洲性一区二区| 丰满少妇高潮无套内谢| 国产欧美日韩精品丝袜高跟鞋| 日本亚洲色大成网站www久久| 亚洲一级特黄大片在线播放| 欧美国产综合视频| 亚洲日韩精品无码一区二区三区| 欲色欲色天天天www| 国产精品自在线拍国产手机版 | 国内精品久久久久影院网站 | 亚洲av日韩av综合在线观看| 免费国产va在线观看| 亚洲区成人综合一区二区| 亚洲av天堂综合网久久| 亚洲av日韩av一区久久| 国产成人亚洲精品狼色在线| 四虎永久免费高清视频| 无码人妻丰满熟妇奶水区码 | 91一区二区三区蜜桃臀| A级毛片无码久久精品免费| 99蜜桃在线观看免费视频网站| 国产玖玖玖玖精品电影| 日韩一区在线中文字幕| 亚洲伊人成无码综合网| 青青青爽在线视频观看| 国产伦人人人人人人性| 中文字幕精品人妻丝袜| 平塘县| 国产免费午夜福利在线观看| 男人狂桶女人出白浆免费视频| 欧美激情在线播放| 亚洲成在人线AⅤ中文字幕| 99久久久国产精品消防器材| 人妻少妇偷人无码视频| 久热re这里精品视频在线6| 亚洲大成色www永久网站动图| 亚洲日韩一区二区|