GitHub倉庫導入Gitee后同步更新的方案思考

背景:

故事的起因是 保利威多場景SDK為方便客戶下載demo項目代碼倉庫以及使用集成文檔狭握,將項目倉庫以及集成文檔都放在Github中彪杉。客戶在使用查閱時會出現(xiàn)從保利威幫助中心跳轉(zhuǎn)到github這一不方便的操作罩锐,更甚者會受到墻的原因而訪問不穩(wěn)定求泰,無法獲取到demo或者通過集成文檔解決問題,這也無形中增大了售前售后對接的壓力硅卢,因此21年底射窒,保利威也在Gitee中將Github倉庫做了遷移。

在將Github倉庫的內(nèi)容遷移到Gitee中将塑,因為使用了相對地址脉顿,導致遷移后gitee一些鏈接跳轉(zhuǎn)錯誤,或者又跳轉(zhuǎn)到github中去点寥。為了不產(chǎn)生鏈接跳轉(zhuǎn)的問題艾疟,也對Gitee倉庫中項目以及Wiki中涉及的超鏈接鏈地址做了改造。我們將一些文檔中指向github的超鏈接變?yōu)榱薌itee,可以將鏈接跳轉(zhuǎn)控制在Gitee內(nèi)蔽莱。

那么問題來了弟疆,如何做到同步更新呢?

一盗冷、三種同步更新的方法

在Gitee幫助中心中提供了三種同步更新的方案怠苔,原文點擊此處跳轉(zhuǎn):https://gitee.com/help/articles/4284#article-header1

1、對于分支較少的倉庫

1正塌、首先通過 git remote -v 查看您要同步的倉庫的遠程庫列表嘀略,如果在列表中沒有您 Gitee 的遠程庫地址恤溶,您需要新增一個地址

git remote add 遠程庫名 遠程庫地址
eg: git remote add gitee git@github.com:xxx/xxx.git

如果在 add 的時候出現(xiàn)error: Could not remove config section 'remote.xxx'.一類的錯誤乓诽,通過把倉庫下.git/config 文件里面的 [remote "xxx"] 刪掉或者是用別的遠程庫名即可。

2咒程、從 GitHub 上拉取最新代碼到本地

git pull 遠程庫名 分支名
eg:git pull origin master

3鸠天、推送本地最新代碼到 Gitee 上

git push 遠程庫名 分支名
eg:git push gitee master

如果出現(xiàn)有差異的話需要自己手動解決差異

簡單來說,就是通過添加不同名稱標識的遠程庫帐姻,拉取github分支到本地稠集,如下圖在sourcetree中所示 origin為gitee遠程庫、github為github遠程庫饥瓷。

示例圖片

再合并到gitee本地分支剥纷,解決沖突后推送到gitee。

2呢铆、對于分支較多的倉庫-腳本方法

1晦鞋、克隆 GitHub 倉庫到本地,命令如下

$ git clone git@github.com:xxx/xxx.git

進入倉庫目錄

$ cd xxx

2棺克、一次性拉取該倉庫的所有分支悠垛,命令如下:

$ for b ingit branch -r | grep -v -- '->'; do git branch --track ${b##origin/} $b; done

3、查看所有分支(包括本地和遠程倉庫分支)

git branch --all

4娜谊、推送本地倉庫到 Gitee 上

這種方案更適合自動化腳本的使用确买,拉取所有分支再推送上去。

3纱皆、對于分支較多的倉庫-主頁點擊

直接在倉庫主頁點擊同步

gitee示例

在這個同步功能也可以勾選同步wiki進行覆蓋


gitee示例

二湾趾、我們的選擇

在背景中提到,在將倉庫遷移到Gitee后派草,對項目ReadMe搀缠、Wiki文檔中一些超鏈接做了調(diào)整。這種差異導致我們在三種方法中不得不放棄了最簡單直接的方法三——倉庫主頁同步按鈕直接覆蓋澳眷。

在方案一胡嘿、方案二的抉擇中,我們也是選擇了方案一钳踊。主要原因是:

  1. DEMO項目面向客戶提供衷敌,分支較少勿侯,且主要使用的是master分支
  2. 因為文檔超鏈接的差異,不得不合并兩邊的代碼以避免沖突缴罗。

每當多場景Demo項目完成一次發(fā)版更新助琐,就要有負責維護Gitee的同學做一次分支合并的操作,雖然耗時不多面氓,但也在降低發(fā)版的效率兵钮。

為了使用方案三,我們決定將引起差異的外部鏈接舌界,都遷移到自家的幫助中心掘譬,比如版本的發(fā)布記錄、項目的集成文檔呻拌。這樣Github倉庫和Gitee倉庫只作為了代碼倉庫葱轩,即使出現(xiàn)需要超鏈接的部分,也只會指向同一個域名藐握,不會出現(xiàn)代碼上的差異靴拱。

建議

不論后面是否有遷移倉庫的需求,我們也是建議在開發(fā)過程中將代碼倉庫中涉及的超鏈接可以使用絕對地址猾普。

對于需要使用Wiki袜炕,有條件的能將Wiki放在自家域名下管理。

?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末初家,一起剝皮案震驚了整個濱河市偎窘,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌笤成,老刑警劉巖评架,帶你破解...
    沈念sama閱讀 216,692評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異炕泳,居然都是意外死亡纵诞,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,482評論 3 392
  • 文/潘曉璐 我一進店門培遵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來浙芙,“玉大人,你說我怎么就攤上這事籽腕∥撕簦” “怎么了?”我有些...
    開封第一講書人閱讀 162,995評論 0 353
  • 文/不壞的土叔 我叫張陵皇耗,是天一觀的道長南窗。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么万伤? 我笑而不...
    開封第一講書人閱讀 58,223評論 1 292
  • 正文 為了忘掉前任窒悔,我火速辦了婚禮,結果婚禮上敌买,老公的妹妹穿的比我還像新娘简珠。我一直安慰自己,他們只是感情好虹钮,可當我...
    茶點故事閱讀 67,245評論 6 388
  • 文/花漫 我一把揭開白布聋庵。 她就那樣靜靜地躺著,像睡著了一般芙粱。 火紅的嫁衣襯著肌膚如雪祭玉。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,208評論 1 299
  • 那天宅倒,我揣著相機與錄音攘宙,去河邊找鬼屯耸。 笑死拐迁,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的疗绣。 我是一名探鬼主播线召,決...
    沈念sama閱讀 40,091評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼多矮!你這毒婦竟也來了缓淹?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,929評論 0 274
  • 序言:老撾萬榮一對情侶失蹤塔逃,失蹤者是張志新(化名)和其女友劉穎讯壶,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體湾盗,經(jīng)...
    沈念sama閱讀 45,346評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡伏蚊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,570評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了格粪。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片躏吊。...
    茶點故事閱讀 39,739評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖帐萎,靈堂內(nèi)的尸體忽然破棺而出比伏,到底是詐尸還是另有隱情,我是刑警寧澤疆导,帶...
    沈念sama閱讀 35,437評論 5 344
  • 正文 年R本政府宣布赁项,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏悠菜。R本人自食惡果不足惜紫新,卻給世界環(huán)境...
    茶點故事閱讀 41,037評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望李剖。 院中可真熱鬧芒率,春花似錦、人聲如沸篙顺。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,677評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽德玫。三九已至匪蟀,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間宰僧,已是汗流浹背材彪。 一陣腳步聲響...
    開封第一講書人閱讀 32,833評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留琴儿,地道東北人段化。 一個月前我還...
    沈念sama閱讀 47,760評論 2 369
  • 正文 我出身青樓,卻偏偏與公主長得像造成,于是被迫代替她去往敵國和親显熏。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,647評論 2 354

推薦閱讀更多精彩內(nèi)容