婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 一次因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錯誤使用引發的問題與解決的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品伦理一区二区| 国产精品家庭影院| 日韩免费电影网站| 亚洲一二三专区| 一本色道综合亚洲| 亚洲欧美日韩中文播放| 国产在线观看一区二区| 精品日韩一区二区三区免费视频| 日韩一区欧美二区| 欧美一区二区三区小说| 美女视频第一区二区三区免费观看网站| 91影视在线播放| 亚洲视频小说图片| 欧美另类高清zo欧美| 亚洲综合成人网| 99在线精品观看| 中文文精品字幕一区二区| 国产一区欧美二区| 国产精品免费人成网站| 97精品电影院| 亚洲福利视频一区二区| 91精品国产乱码| 国产在线不卡视频| 中文字幕在线观看不卡视频| 91片在线免费观看| 亚洲影院理伦片| 在线成人免费视频| 国产精品亚洲第一| 一区二区三区日韩在线观看| 欧美喷潮久久久xxxxx| 国产米奇在线777精品观看| 欧美国产日韩在线观看| 91激情五月电影| 国产在线播放一区| 国产精品久久久久久妇女6080| 成人免费观看av| 亚洲欧美日韩国产手机在线| 91精品国产综合久久久久| 久久99国产精品久久99果冻传媒| 久久九九久久九九| 欧美三级视频在线观看| 国产麻豆9l精品三级站| 亚洲一区欧美一区| 国产日韩成人精品| 日韩亚洲欧美一区| 在线观看日产精品| 国产精品一级片在线观看| 日韩中文字幕亚洲一区二区va在线 | 久久99精品久久久| 国产精品久久久久一区二区三区| 欧美午夜精品一区二区三区| 国产成人免费视频一区| 亚洲午夜在线视频| 亚洲视频一区二区免费在线观看 | 欧美一卡2卡3卡4卡| 色久优优欧美色久优优| jiyouzz国产精品久久| 国产精品综合一区二区| 美日韩黄色大片| 亚洲成人精品一区二区| 亚洲精品国产a| 中文字幕一区日韩精品欧美| 久久久久久免费| 日韩一区二区三区在线| 欧美日韩一区二区三区高清| 欧美在线免费播放| 欧美视频在线不卡| 欧洲一区二区av| 欧美制服丝袜第一页| 成人精品视频一区二区三区尤物| 日韩高清不卡一区二区| 亚洲欧洲制服丝袜| 亚洲精品精品亚洲| 亚洲永久免费av| 亚洲国产精品一区二区尤物区| 亚洲美女淫视频| 亚洲最新在线观看| 亚洲国产综合在线| 蜜桃一区二区三区四区| 精品一区二区在线视频| 国产乱码精品一区二区三| 国产一区二区女| 风间由美一区二区三区在线观看| 成人动漫一区二区在线| 成人蜜臀av电影| 91色在线porny| 在线区一区二视频| 在线成人高清不卡| 久久老女人爱爱| 中文字幕一区二区三区不卡在线| 自拍偷拍欧美激情| 日韩精品国产精品| 国产精品亚洲人在线观看| 色综合 综合色| 欧美一二三区精品| 日本一区二区免费在线| 中文字幕av资源一区| 亚洲不卡av一区二区三区| 日本在线不卡一区| 国产成人久久精品77777最新版本| jiyouzz国产精品久久| 91麻豆精品久久久久蜜臀| 久久久久久久久久久久久夜| 亚洲综合激情网| 久久国产精品72免费观看| 91一区二区三区在线播放| 欧美精品777| 亚洲欧美综合色| 日韩精品一二三区| eeuss鲁一区二区三区| 欧美一区二区人人喊爽| 国产精品国产三级国产aⅴ中文 | 亚洲同性同志一二三专区| 水野朝阳av一区二区三区| 成人丝袜18视频在线观看| 欧美一区二区播放| 亚洲男人天堂一区| 国产经典欧美精品| 欧美精品视频www在线观看| 成人免费在线观看入口| 国产一区日韩二区欧美三区| 欧美肥妇bbw| 亚洲一区在线视频| 成人黄动漫网站免费app| 日韩精品一区二| 香蕉加勒比综合久久| 99久久er热在这里只有精品15| 日韩精品一区二区在线观看| 一区二区三区欧美亚洲| 丁香另类激情小说| 久久久另类综合| 日韩精品成人一区二区在线| av电影一区二区| 国产精品的网站| 成人黄色软件下载| 国产精品久久免费看| 丁香六月综合激情| 日本一区二区在线不卡| 国产一区二区视频在线播放| 精品国产露脸精彩对白| 免费高清在线视频一区·| 91精品久久久久久久99蜜桃| 天天色天天操综合| 91精品国产一区二区三区蜜臀| 亚洲电影中文字幕在线观看| 欧美三区在线视频| 视频一区欧美日韩| 日韩一区二区不卡| 美女看a上一区| 精品国产91九色蝌蚪| 国内精品免费在线观看| 久久色.com| 不卡的av中国片| 伊人夜夜躁av伊人久久| 91色乱码一区二区三区| 亚洲一区二区三区四区五区黄| 欧美性生活大片视频| 美国十次综合导航| 精品成人在线观看| 大陆成人av片| 亚洲人成7777| 欧美日韩国产片| 国内成人自拍视频| 国产精品伦理一区二区| 欧美视频一区二区在线观看| 日本vs亚洲vs韩国一区三区| 久久综合狠狠综合久久激情 | 色婷婷国产精品综合在线观看| 亚洲欧美一区二区三区久本道91 | 国产精品污污网站在线观看| 在线免费观看不卡av| 免费观看日韩av| 久久天天做天天爱综合色| 91在线观看美女| 美女国产一区二区| 亚洲色图制服诱惑 | 欧美日韩一级视频| 另类小说图片综合网| 亚洲丝袜美腿综合| 欧美一级免费大片| caoporm超碰国产精品| 五月综合激情网| 国产网站一区二区三区| 欧美日韩一区小说| 成人综合婷婷国产精品久久| 五月天视频一区| 国产精品久久久久久久蜜臀| 欧美日韩一区成人| 波多野结衣亚洲| 国内精品写真在线观看| 一区二区三区国产精品| 久久青草欧美一区二区三区| 欧美午夜精品久久久久久超碰 | 91福利在线播放| 国产精品99久久不卡二区| 亚洲午夜久久久久久久久久久| 久久精品夜夜夜夜久久| 在线播放91灌醉迷j高跟美女| 丁香另类激情小说| 国产在线乱码一区二区三区|