亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

一次因composer錯誤使用引發的問題與解決

2024-05-05 00:07:10
字體:
來源:轉載
供稿:網友

前言

這個思考源自于一個事故。讓我對版本依賴重新思考了一下。分享出來供有需要的朋友們參考學習,下面話不多說了,來一起看看詳細的介紹吧

事故現象

一個線上的管理后臺,一個使用laravel搭建的管理后臺,之前在線上跑的好好的,今天comopser install之后,出現錯誤信息:

[2019-02-25 16:00:33] production.ERROR: Parse error: syntax error, unexpected '?', expecting variable (T_VARIABLE) {"exception":"[object] (Symfony//Component//Debug//Exception//FatalThrowableError(code: 0): Parse error: syntax error, unexpected '?', expecting variable (T_VARIABLE) at /xxxx/application/estimate-admin/vendor/symfony/translation/Translator.php:89)

事故分析

這個是個底層庫,基本上,一看就知道是版本兼容問題,進去代碼一看,里面有行代碼是 ?string,這個是php7.1引入的一種新特性。

看了下我的composer.json,里面主要引用的是laravel的框架,之前的laravel/framework的版本是"~5.5"

于是想當然以為是laravel的版本升級導致的,于是我把laravel的版本固定到一個子版本

"laravel/framework": "5.5.21",

發現還是會出現這個錯誤。估摸可能不是laravel版本升級導致的。于是從laravel的版本依賴追到問題的包"symfony/translation"。

鏈條如下:

我的項目 "laravel/framework": "5.5.21",
  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也有,基本注意點都是如上,一樣的。


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97在线看免费观看视频在线观看| 国产精品欧美日韩| 国产精品自在线| 精品视频在线导航| 亚洲欧美一区二区精品久久久| 欧美日韩xxxxx| 国模精品视频一区二区| 亚洲精品v天堂中文字幕| 久久伊人精品一区二区三区| 少妇久久久久久| 国产精品旅馆在线| 亚洲免费伊人电影在线观看av| 亚洲午夜未满十八勿入免费观看全集| 丰满岳妇乱一区二区三区| 中文字幕国产精品| 亚洲一区二区国产| 日韩中文视频免费在线观看| 久久69精品久久久久久国产越南| 亚洲精品视频二区| 国产亚洲精品久久久久久| 51精品在线观看| 久久人人爽人人爽人人片av高请| 成人97在线观看视频| 国产视频亚洲精品| 成人免费视频在线观看超级碰| 欧美成人黑人xx视频免费观看| 欧美一级片久久久久久久| 欧美另类xxx| 57pao国产成人免费| 国内精品久久久久久| 欧美性黄网官网| 亚洲国产欧美久久| 亚洲精品国产综合区久久久久久久| 国产成人精品视| 亚洲二区中文字幕| 狠狠干狠狠久久| 欧美激情a∨在线视频播放| 欧美一级黑人aaaaaaa做受| 欧美国产日韩中文字幕在线| 亚洲色图激情小说| 亚洲欧美精品一区二区| 欧美巨大黑人极品精男| 91av视频在线| 日韩成人中文字幕在线观看| 日韩电视剧免费观看网站| 2019国产精品自在线拍国产不卡| 欧美一区二区大胆人体摄影专业网站| 亚洲欧美一区二区三区在线| 欧美床上激情在线观看| 97国产精品人人爽人人做| 成人啪啪免费看| 欧美另类99xxxxx| 在线电影中文日韩| 国产精品久久久久久久久久新婚| 日本精品久久中文字幕佐佐木| 欧美人在线观看| 欧美成人在线网站| 久久精品亚洲94久久精品| 日韩精品免费视频| 91在线看www| 91天堂在线观看| 最近中文字幕日韩精品| 欧美性xxxx极品hd满灌| 亚洲视频日韩精品| 日韩最新在线视频| 国产在线拍偷自揄拍精品| 久久久久久久久91| 亚洲视频在线视频| 亚洲国产精品成人av| 日韩视频在线一区| 美女福利视频一区| 成人免费看片视频| 亚洲欧美综合区自拍另类| 久久久国产精品亚洲一区| 久久精品视频va| 国产精品视频一区二区三区四| 亚洲精品久久久久久久久| 欧美美最猛性xxxxxx| 国产成人高清激情视频在线观看| 成人福利网站在线观看11| 国产69精品久久久久9| 亚洲成**性毛茸茸| 欧美壮男野外gaytube| 欧美激情一区二区三区成人| 欧美精品久久久久a| 91国产精品91| xvideos成人免费中文版| 在线国产精品播放| 日韩在线高清视频| 富二代精品短视频| 不卡av电影在线观看| 日本一欧美一欧美一亚洲视频| 欧美性猛交xxxx| 欧美激情欧美狂野欧美精品| 日本精品视频在线播放| 88国产精品欧美一区二区三区| 欧美日韩另类字幕中文| 国产精品一区二区3区| 亚洲欧洲免费视频| 亚洲国产欧美一区二区三区久久| 懂色av影视一区二区三区| 欧美日本亚洲视频| 一区二区三区www| 亚洲一区二区三区xxx视频| 欧美亚洲在线观看| 国产精品www| 日韩在线观看免费网站| 成人免费视频在线观看超级碰| 日韩欧美亚洲一二三区| 国产欧美日韩中文字幕在线| 亚洲精品国产精品自产a区红杏吧| 蜜月aⅴ免费一区二区三区| 国产不卡一区二区在线播放| 国产精品av在线播放| 97精品欧美一区二区三区| 亚洲国产女人aaa毛片在线| 亚洲一区二区免费在线| 欧美日韩国产麻豆| 国产精品视频公开费视频| 国产精品久久av| 亚洲视频在线免费看| 亚洲情综合五月天| 午夜精品福利在线观看| 久久久久亚洲精品| 国产91色在线播放| 国产精品99久久久久久人| 亚洲精品国产精品久久清纯直播| 97免费在线视频| 日韩精品免费在线视频观看| www.亚洲成人| 亚洲自拍偷拍色片视频| 国产精品一区二区久久| 色哟哟网站入口亚洲精品| 久久久久久久久久国产精品| 欧美怡红院视频一区二区三区| 亚洲一区二区久久久久久久| 国产精品扒开腿做爽爽爽视频| 色老头一区二区三区| 成人激情视频网| 亚洲毛茸茸少妇高潮呻吟| 欧美日本中文字幕| 国产精品中文字幕久久久| 国产欧美一区二区三区在线看| 91禁外国网站| 精品福利免费观看| 久久久久日韩精品久久久男男| 久久国产精品电影| 成人亲热视频网站| 中文字幕在线看视频国产欧美| 欧美最顶级丰满的aⅴ艳星| 久久国产一区二区三区| 欧美孕妇毛茸茸xxxx| 亚洲免费伊人电影在线观看av| 欧美亚洲激情在线| 97在线视频一区| 欧美日韩在线视频一区二区| 97精品久久久中文字幕免费| 国内精品免费午夜毛片| 国产精品老女人精品视频| 97精品久久久中文字幕免费| 91精品国产综合久久香蕉的用户体验| 国产美女直播视频一区| 国产精品老女人视频| 91影视免费在线观看|