摘要:使用打包壓縮靜態文件的時候,兩個項目必須在同一個分支,很容易搞亂。第三階段使用如果是引用多個子項目,會造成當前項目過于臃腫。參考文章官網文檔使用集成項目到子目錄用在多個項目間雙向同步子項目,附簡明使用手冊
背景
最近工作中遇到了一個問題:隨著項目越來越多,很多項目依賴同一個模板或是配置文件想同一管理,又不想分開維護,所以只能互相引用,或是各自維護,導致了后續的很多麻煩。
場景一: 很多公司手機端和pc同時開發,引用同一套模板,或者通用的組件庫。
場景二: 用gulp、webpack來打包,或是用node來開發會有一些通用的配置文件需要統一管理。
第一階段:gulp等自動化工具手動同步這個是我們最初使用的方法,比如有兩個項目projectA和projectB,B項目依賴A項目中的一套模板,會遇到幾個問題:
開發中我們引用模塊的時候,B項目要經過很長的路徑引用才能引到A項目中的模板,這要求所有開發者本地文件路徑保持高度一致。
使用webpack打包壓縮靜態文件的時候,A、B兩個項目必須在同一個git分支,很容易搞亂。
修改完文件不能及時看到效果,還要手動同步一次。這點是開發中最致命的問題,做前端的都會有體會如果改了一個樣式或是一個模板要通過一個很長的操作路徑才能看到效果,是非常影響開發效率的。
在用了幾個月之后,各種問題暴露出來,我們必須找新的辦法。
第二階段:使用Git subtree網上調研了很多方法,例如git submodule,第二階段最終選擇了subtree,一是官網已經不再推薦使用submodule了,二是subtree實在是太方便易用了。(后來和同事商量了下發現submodule還是有使用價值的,在第三階段中我們再分析。)
說到subtree易用,只需要2步就可以初始化好一個子項目:
第一步:添加遠程倉庫語法:git remote add -f <子倉庫名> <子倉庫地址>
實例:git remote add -f component git@xxx.git
驗證:git remote -v 可以看到已經你添加成功了一個新的遠程倉庫叫 component
第二步:創建本地目錄語法:git subtree add --prefix=<子目錄名> <子倉庫名> <分支> --squash
實例:git subtree add --prefix=component component master --squash
這時候會在本地新建一個叫component的文件夾,--squash 會把subtree上的改動合并成一次commit
第三步:使用 ( pull & push )pull:git subtree pull --prefix=component component master --squash
push:git subtree push --prefix=component component master --squash
注意:必須在component的父級目錄執行,使用起來還不是很方便。
第四步:更方便的使用可以在package.json里面加script語句來執行,這樣在每個文件夾下都可以pull & push,強制統一,避免出錯。
第三階段:使用Git submodule如果是引用多個子項目,會造成當前項目過于臃腫。其實有的時候類似組件庫是不需要上線的,只在開發環境引用就好了。
添加:git submodule add
添加后會在當前目錄下生成一個.gitmodules的新文件,里面會記錄submodule的引用信息,在當前項目的位置以及倉庫的url。
git submodule foreach git pull 這樣可以更新所有子模塊。
這里只介紹了最基本的submodule用法,實際在多個項目中更新和修改submodule還是很多坑的,可以參考這篇文章 Git Submodule的坑。 所以我們規定在項目中只能pull子模塊,修改的話只能到子模塊中去push。 這樣避免了多人修改造成的沖突。
結論參考文章在新員工加入團隊時:一次性clone項目,submodule可以一起clone出來,只需添加--recursive遞歸參數就可以了,而subtree并不行,只能手動添加,不過可以借助神器Yeoman(一個自動生成項目腳手架的工具)來實現。
subtree適合像配置文件這種需要跟著項目走的情況。
submodule適合在開發階段時引用,到了生產環境會被打包到指定文件內,而本身并不用跟著版本走的情況。
官網文檔:Git Tools - Subtree Merging
使用GIT SUBTREE集成項目到子目錄
用 Git Subtree 在多個 Git 項目間雙向同步子項目,附簡明使用手冊
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/86442.html
摘要:也授予其榮譽數據科學家稱號。教學案例以上的實戰派數據科學大佬們,也正式成為了數據分析研究院榮譽科學家成員,共同參與制定數據科學家人才標準大綱及數據科學家精英培訓,將自身在大數據發展這幾年的實戰成果,以教學案例的形式傾囊相授。 showImg(https://segmentfault.com/img/bVbofUw?w=865&h=592); 在大家的眼中,科學家的形象可能是一位表情嚴肅...
摘要:雖然我們可以在網上參照各種模板項目文章博客等創建一個數據科學項目,但是目前也沒有教科書對這些知識做一個統一的回答。舉個例子來說,數據科學分析項目通常就不需要部署和監控這兩個過程。創建文件描述源數據及位置。進一步探索和報告在整個數據科學項目中 摘要:?在一個新的數據科學項目,你應該如何組織你的項目流程?數據和代碼要放在那里?應該使用什么工具?在對數據處理之前,需要考慮哪些方面?讀完本文...
摘要:在此次會議上,還計劃發布云計算深度學習服務。兩名消息人士表示,新的深度學習服務也幫助用戶更方便地運行常見深度學習開發工具包,例如和谷歌。谷歌和微軟已提供類似的服務。 據外媒報道,亞馬遜AWS正在大力推動人工智能產品的升級,包括自主開發技術以及與多家AI創業公司合作。AWS希望補足自身短板,贏得更多人工智能業務...
摘要:在此次會議上,還計劃發布云計算深度學習服務。兩名消息人士表示,新的深度學習服務也幫助用戶更方便地運行常見深度學習開發工具包,例如和谷歌。谷歌和微軟已提供類似的服務。 據外媒報道,亞馬遜AWS正在大力推動人工智能產品的升級,包括自主開發技術以及與多家AI創業公司合作。AWS希望補足自身短板,贏得更多人工智能業務。總體來說,AWS在人工智能領域的工作以Ironman項目為中心。Ironman項目...
摘要:背景近年來,人工智能與數據科學領域發展迅速,傳統項目在演化中也越來越復雜了,如何管理大量的機器學習項目成為一個難題。在真正的機器學習項目中,我們需要在模型之外花費大量的時間。 showImg(https://segmentfault.com/img/remote/1460000016855989?w=800&h=450); 背景 近年來,人工智能與數據科學領域發展迅速,傳統項目在演化中...
閱讀 1039·2021-11-18 13:23
閱讀 746·2021-11-08 13:16
閱讀 855·2021-10-11 10:58
閱讀 3510·2021-09-22 15:26
閱讀 1732·2021-09-08 10:42
閱讀 1807·2021-09-04 16:45
閱讀 1733·2019-08-30 15:54
閱讀 2564·2019-08-30 13:45