欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > 一次因composer錯誤使用引發的問題與解決

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

熱門標簽:十堰ai電話機器人效果怎么樣 上海公司外呼系統線路 銀川ai電話機器人 浙江外呼電話系統軟件 臨沂智能電銷機器人軟件 芒果電銷機器人 地圖標注風向標 安陽自動外呼系統價格是多少 電梯外呼線路板維修視頻

前言

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

事故現象

一個線上的管理后臺,一個使用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也有,基本注意點都是如上,一樣的。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • Laravel框架中composer自動加載的實現分析
  • PHP管理依賴(dependency)關系工具 Composer的自動加載(autoload)
  • Laravel 解決composer相關操作提示php相關異常的問題
  • laravel 實現向公共模板中傳值 (view composer)
  • 淺談laravel 5.6 安裝 windows上使用composer的安裝過程
  • 使用composer 安裝 laravel框架的方法圖文詳解
  • tp5框架使用composer實現日志記錄功能示例
  • windows環境下使用Composer安裝ThinkPHP5
  • PHP創建自己的Composer包方法
  • 分析Composer實現自動加載原理

標簽:徐州 武威 寧夏 常州 荊門 吐魯番 遂寧 遵義

巨人網絡通訊聲明:本文標題《一次因composer錯誤使用引發的問題與解決》,本文關鍵詞  一次,因,composer,錯誤,使用,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《一次因composer錯誤使用引發的問題與解決》相關的同類信息!
  • 本頁收集關于一次因composer錯誤使用引發的問題與解決的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    欧美v日韩v国产v| 狠狠狠色丁香婷婷综合激情 | 亚洲在线成人精品| 99久久婷婷国产综合精品 | 蜜臀久久99精品久久久久久9| 国产在线观看免费播放| 欧美在线free| 一区二区高清免费观看影视大全| 99久久精品情趣| 色婷婷国产精品综合在线观看| 国产精品久久精品日日| 丁香另类激情小说| 精品一区在线观看视频| 中文字幕日韩一区| av一二三不卡影片| 日本久久精品电影| 一区二区三区不卡在线观看| 日本人妻一区二区三区| 欧美日韩国产美| 天天综合天天综合色| 97人妻精品一区二区三区免| 欧美电影免费观看高清完整版在| 男女性色大片免费观看一区二区 | 欧美一区二区三区四区高清| 亚洲 欧美综合在线网络| 精品人妻伦一二三区久| 日韩视频一区二区三区| 九九视频精品免费| 三级黄色在线观看| 综合激情成人伊人| 亚洲911精品成人18网站| 69精品人人人人| 免费成人在线网站| 成年人看的免费视频| 国产精品久99| 中文字幕在线播放一区二区| 欧美一级高清大全免费观看| 激情小说欧美图片| 在线看的片片片免费| 一区二区三区在线影院| v天堂中文在线| 精品99一区二区| 盗摄精品av一区二区三区| 在线观看一区二区精品视频| 五月激情六月综合| 国产大屁股喷水视频在线观看| 久久精品无码专区| 欧美一级片免费看| 国产激情一区二区三区四区| 色婷婷av一区二区三区之一色屋| 亚洲成人av一区二区三区| 中文字幕免费视频| 亚洲欧洲一区二区在线播放| 永久免费未满蜜桃| 久久久久久久久久久久久女国产乱| 成人美女视频在线观看18| 欧美三区免费完整视频在线观看| 青青草伊人久久| 人妻人人澡人人添人人爽| 亚洲成人av资源| 伊人久久久久久久久久久久久久| 亚洲综合av网| 国精产品一区一区| 亚洲一区二区偷拍精品| 99久久精品免费视频| 亚洲精品亚洲人成人网在线播放| 丰满少妇一区二区三区| 18成人在线观看| 免费无码一区二区三区| 国产精品日产欧美久久久久| 一级欧美一级日韩片 | 欧美亚一区二区三区| 国产精品久久久一区麻豆最新章节| 在线播放第一页| 国产精品乱人伦中文| 日本少妇毛茸茸| 亚洲日本一区二区| 四季av中文字幕| 午夜免费欧美电影| 中文字幕另类日韩欧美亚洲嫩草| 天天综合天天综合色| 一本色道久久综合亚洲精品按摩| 久久精品免费观看| 欧美日韩性生活| 成人三级在线视频| 久久久亚洲精华液精华液精华液| 日本一区二区免费视频| 国产精品国产三级国产专播品爱网 | 受虐m奴xxx在线观看| 一区二区三区四区国产精品| 日本女人性生活视频| 秋霞av亚洲一区二区三| 欧美色大人视频| 国产精品自拍av| 日韩丝袜情趣美女图片| 三级网站免费看| 亚洲欧洲日韩一区二区三区| 亚洲精品国产一区黑色丝袜 | 一区二区三区日韩精品视频| 久久美女免费视频| 日韩国产欧美视频| 欧美日韩在线播放一区| 99国产精品久久久久久久久久久| 国产丝袜欧美中文另类| 久久久久久久久久久久| 午夜久久久久久电影| 欧美日韩专区在线| 99re在线视频这里只有精品| 国产精品人成在线观看免费 | 国产精品一二三区| 久久影音资源网| 37p粉嫩大胆色噜噜噜| 亚欧色一区w666天堂| 欧美另类videos死尸| 91视频免费入口| 亚洲欧洲成人精品av97| 日韩一卡二卡在线观看| 精品一区二区三区在线观看国产| 日韩欧美国产系列| www.久久av| 日韩电影免费在线观看网站| 91麻豆精品国产91| yy1111111| 日本v片在线高清不卡在线观看| 在线成人小视频| 国产精品久久久久久在线观看| 亚洲午夜精品久久久久久久久| 欧美丝袜自拍制服另类| 久久久久亚洲av无码麻豆| 一卡二卡欧美日韩| 欧美午夜精品一区二区蜜桃| 精产国品一区二区三区| 一区二区国产盗摄色噜噜| 欧美中文字幕亚洲一区二区va在线| 91在线码无精品| 亚洲一区欧美一区| 91.麻豆视频| 免费成人深夜夜行p站| 久久精品国产99| 久久久精品国产免费观看同学| 国产精品久久久久久久av| 国产美女精品人人做人人爽| 国产欧美1区2区3区| 日本在线一级片| 91丨porny丨国产入口| 亚洲大片免费看| 欧美成人一区二区三区在线观看| 自拍偷拍视频亚洲| 国产成人av自拍| 亚洲精品免费看| 91精品福利在线一区二区三区| 3d动漫精品啪啪一区二区下载| 韩国av一区二区三区在线观看| 中文无字幕一区二区三区| 国产精品九九九九九九| 欧美一级大片免费看| 日本免费在线视频不卡一不卡二| 精品盗摄一区二区三区| 91人妻一区二区三区蜜臀| 久久久久国产免费| 蜜桃久久精品一区二区| 国产精品久久久久影院色老大 | 日韩欧美的一区| 国产精品成人无码免费| 成人免费黄色在线| 亚洲一区二区三区中文字幕| 日韩欧美一区二区不卡| 美国一级黄色录像| 91社区在线播放| 日本欧美大码aⅴ在线播放| 国产婷婷精品av在线| 欧美日韩专区在线| 精品日韩在线视频| 午夜诱惑痒痒网| 久久精工是国产品牌吗| 中文字幕在线视频一区| 欧美高清www午色夜在线视频| 我想看黄色大片| 成人三级做爰av| 久久er99热精品一区二区| 亚洲男人的天堂网| 精品日韩一区二区三区| 少妇影院在线观看| www.超碰97| 成人app网站| 男人操女人的视频在线观看欧美 | 成人在线综合网站| 日韩一区精品视频| 国产精品久久久久久久久免费桃花| 欧美日本在线一区| 91香蕉一区二区三区在线观看| 艳妇乳肉亭妇荡乳av| 成人黄色片在线观看| 日本不卡高清视频| 亚洲毛片av在线| 久久久精品免费网站| 91精品国产入口| 国内偷拍精品视频| 久久亚洲无码视频| 午夜福利三级理论电影|