SourceTree使用(II)

終端一般 Git命令

增加新功能

///從dev建立特性分支
(dev)$: git checkout -b feature/xxx   

///開發(fā)        
(feature/xxx)$: blabla                         
(feature/xxx)$: git add xxx
(feature/xxx)$: git commit -m 'commit comment'

///把特性分支合并到dev
(dev)$: git merge feature/xxx --no-ff          


修復(fù)緊急bug

///從master建立hotfix分支
(master)$: git checkout -b hotfix/xxx   

///開發(fā)      
(hotfix/xxx)$: blabla                        
(hotfix/xxx)$: git add xxx
(hotfix/xxx)$: git commit -m 'commit comment'

/// 把hotfix分支合并到master遗增,并上線到生產(chǎn)環(huán)境
(master)$: git merge hotfix/xxx --no-ff  

///把hotfix分支合并到dev适荣,同步代碼     
(dev)$: git merge hotfix/xxx --no-ff        



測試環(huán)境代碼

///把dev分支合并到release励背,然后在測試環(huán)境拉取并測試
(release)$: git merge dev --no-ff             


生產(chǎn)環(huán)境上線

///把testing測試好的代碼合并到master,運(yùn)維人員操作
(master)$: git merge testing --no-ff   

///給版本命名平斩,打Tag       
(master)$: git tag -a v0.1 -m '部署包版本名' 




新建分支

創(chuàng)建 Develop 分支 步驟

創(chuàng)建了Develop分支恼策,如下:


Develop 分支效果圖



Demo: 創(chuàng)建功能開發(fā)分支feature/Harley

feature/Harley 步驟

效果:


feature 效果圖



遠(yuǎn)程檢出分支

遠(yuǎn)程檢出 develop 分支

檢出 develop 分支

效果圖:


遠(yuǎn)程檢出的 develop 分支




刪除分支

刪除遠(yuǎn)程分支

刪除遠(yuǎn)程分支

? 這是刪除遠(yuǎn)程的分支,本地分支還沒有刪除企孩,需要進(jìn)行下一步刪除本地分支锭碳。


刪除本地分支

刪除 Develop 分支步驟圖




拉取

? master分支的內(nèi)容是最新的,feature/Harley的分支版本落后于master勿璃,從遠(yuǎn)程拉取內(nèi)容合并到feature/Harley的分支上擒抛,如下圖步驟:

拉取 master 分支到 feature/Harley 分支上




合并分支

第一種方法

合并分支


第二種方法

合并Huang 分支到 develop 分支




代碼回滾

適用于的場景:

  • 提交錯(cuò)代碼,想放棄剛剛提交的部分补疑;
  • 代碼發(fā)生沖突歧沪,處理比較麻煩,為了代碼安全莲组,直接回滾到之前干凈的代碼诊胞。

回滾分為本地回滾遠(yuǎn)程回滾;



本地回滾,回滾已經(jīng)提交的代碼胁编,但還未推送到遠(yuǎn)程倉庫厢钧。

選擇回滾到哪次提交

選擇模式進(jìn)行回滾

使用模式:
軟合并:保留上第二次提交的修改內(nèi)容鳞尔,就等第二次提交的【概述】了。
混合合并:保留上第二次提交的修改內(nèi)容早直,就等第二次提交的【概述】了(與軟合并沒啥區(qū)別)寥假。
強(qiáng)行合并:清除第二次提交的所有內(nèi)容,第一次提交的【概述】也沒有了霞扬,好像剛剛第一次的提交糕韧。

效果圖:


本地回滾完成



遠(yuǎn)程回滾
? SourceTree默認(rèn)是不提供這種操作的,因?yàn)榇嬖陲L(fēng)險(xiǎn)喻圃。所以萤彩,回滾遠(yuǎn)程代碼,一定要注意:
①. 想要放棄的代碼斧拍,是所有開發(fā)成員都一致同意的雀扶;
②. 想要放棄的代碼只是自己的,中間沒有別人的提交記錄肆汹,這可以直接回滾愚墓。
③. 這個(gè)操作過程中,提醒其他成員不要推送代碼昂勉。

  • Frist Stemp


    SourceTree 開啟【允許強(qiáng)制推送】權(quán)限
  • Second Stemp


    回滾到想提交的位置
  • Third Stemp


    強(qiáng)制推送

效果圖:


回到了第一次提交位置




變基

變基與合并的區(qū)別

作用:

  • 變基到其他分支浪册,不會(huì)生成新的提交節(jié)點(diǎn);
  • 壓縮提交消息岗照;



①變基到其他分支將Harley 分支內(nèi)容接到 develop

將Harley 分支內(nèi)容接到 develop

注意:在這里村象,先要拉取,再推送攒至,否則會(huì)失敗,下面是推送厚者,如下:

推送develop分支到遠(yuǎn)端




打Tag

功能:

  • 輕量級(jí)的:它其實(shí)是一個(gè)獨(dú)立的分支,或者說是一個(gè)不可變的分支.指向特定提交對(duì)象的引用;
  • 帶附注的:實(shí)際上是存儲(chǔ)在倉庫中的一個(gè)獨(dú)立對(duì)象,它有自身的校驗(yàn)和信息迫吐,包含著標(biāo)簽的名字籍救,標(biāo)簽說明,標(biāo)簽本身也允許使用 GNU Privacy Guard (GPG) 來簽署或驗(yàn)證,電子郵件地址和日期渠抹,一般我們都建議使用含附注型的標(biāo)簽,以便保留相關(guān)信息闪萄。
添加Tag步驟

也可以像下圖那樣打標(biāo)簽???那樣:


工作流打標(biāo)簽流程

Tag 的使用請(qǐng)看這里梧却。

Tag 和 branch 的區(qū)別:

  • tag 對(duì)應(yīng)某次 commit, 是一個(gè)點(diǎn),是不可移動(dòng)的;
  • branch 對(duì)應(yīng)一系列 commit败去,是很多點(diǎn)連成的一根線放航,有一個(gè)HEAD 指針,是可以依靠 HEAD 指針移動(dòng)的圆裕。

? 所以广鳍,兩者的區(qū)別決定了使用方式荆几,改動(dòng)代碼用 branch ,不改動(dòng)只查看用 tag。

? tag 和 branch 的相互配合使用赊时,有時(shí)候起到非常方便的效果吨铸,例如 已經(jīng)發(fā)布了 v1.0 v2.0 v3.0 三個(gè)版本,這個(gè)時(shí)候祖秒,我突然想不改現(xiàn)有代碼的前提下诞吱,在 v2.0 的基礎(chǔ)上加個(gè)新功能,作為 v4.0 發(fā)布竭缝。就可以 檢出 v2.0 的代碼作為一個(gè) branch 房维,然后作為開發(fā)分支。




Git 工作流

1??在develop 分支建立 release分支

建立release 發(fā)布版本

建立 release 分支的 1.3.7發(fā)布版本




參考資料
Git 分支闡述
sourceTree合并某次提交
source tree進(jìn)行rebase操作
合并多次提交

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末抬纸,一起剝皮案震驚了整個(gè)濱河市咙俩,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌湿故,老刑警劉巖阿趁,帶你破解...
    沈念sama閱讀 219,270評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異晓锻,居然都是意外死亡歌焦,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門砚哆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來独撇,“玉大人,你說我怎么就攤上這事躁锁》紫常” “怎么了?”我有些...
    開封第一講書人閱讀 165,630評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵战转,是天一觀的道長搜立。 經(jīng)常有香客問我,道長槐秧,這世上最難降的妖魔是什么啄踊? 我笑而不...
    開封第一講書人閱讀 58,906評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮刁标,結(jié)果婚禮上颠通,老公的妹妹穿的比我還像新娘。我一直安慰自己膀懈,他們只是感情好顿锰,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,928評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般硼控。 火紅的嫁衣襯著肌膚如雪刘陶。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,718評(píng)論 1 305
  • 那天牢撼,我揣著相機(jī)與錄音匙隔,去河邊找鬼。 笑死浪默,一個(gè)胖子當(dāng)著我的面吹牛牡直,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播纳决,決...
    沈念sama閱讀 40,442評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼碰逸,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了阔加?” 一聲冷哼從身側(cè)響起饵史,我...
    開封第一講書人閱讀 39,345評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎胜榔,沒想到半個(gè)月后胳喷,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,802評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡夭织,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,984評(píng)論 3 337
  • 正文 我和宋清朗相戀三年吭露,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片尊惰。...
    茶點(diǎn)故事閱讀 40,117評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡讲竿,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出弄屡,到底是詐尸還是另有隱情题禀,我是刑警寧澤,帶...
    沈念sama閱讀 35,810評(píng)論 5 346
  • 正文 年R本政府宣布膀捷,位于F島的核電站迈嘹,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏全庸。R本人自食惡果不足惜秀仲,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,462評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望壶笼。 院中可真熱鬧啄育,春花似錦、人聲如沸拌消。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,011評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽墩崩。三九已至氓英,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間鹦筹,已是汗流浹背铝阐。 一陣腳步聲響...
    開封第一講書人閱讀 33,139評(píng)論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留铐拐,地道東北人徘键。 一個(gè)月前我還...
    沈念sama閱讀 48,377評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像遍蟋,于是被迫代替她去往敵國和親吹害。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,060評(píng)論 2 355