您的位置:軟件測(cè)試 > 開(kāi)源軟件測(cè)試 > 開(kāi)源配置管理工具 > SVN
為什么 Git 比 SVN 好
作者:網(wǎng)絡(luò)轉(zhuǎn)載 發(fā)布時(shí)間:[ 2014/1/2 10:44:27 ] 推薦標(biāo)簽:配置管理 SVN Git

SVN對(duì)分支當(dāng)做路徑來(lái)授權(quán),造成管理的負(fù)擔(dān)(參見(jiàn) 前面的描述 ), 因此使用SVN實(shí)現(xiàn)靈活的特性分支開(kāi)發(fā)、可靠的發(fā)布控制(維護(hù)分支凍結(jié))很難。

企業(yè)應(yīng)用Git的困惑之一是如何裁剪出適合自己的工作流。實(shí)際上Git本身已經(jīng)給出范例:

    $ git help workflows

理解Git的應(yīng)用模型并選用合適的服務(wù)器端軟件(如 Gitolite),可以定制出適合自己的工作流。 例如下表是在企業(yè)中使用Git版本控制系統(tǒng)的典型角色劃分:

再來(lái)談?wù)凣it的使用,實(shí)際上Git的設(shè)計(jì)模型非常簡(jiǎn)單,理解了其設(shè)計(jì)思想,可以很容易地掌握 git reset, git checkout, git rebase, git push, git pull 等命令。

誤解7:程序員不喜歡命令行

誰(shuí)說(shuō)Git沒(méi)有好的圖形工具?SVN 有 TortoriseSVN,Git 同樣有 TortoiseGit。 只不過(guò)Git的命令行太好用,使得圖形操作顯得笨拙。

至于Windows用做開(kāi)發(fā)環(huán)境是否還有前途,看看火熱的iOS、Android開(kāi)發(fā)、和優(yōu)雅的 MacBook 知道了。

Git能做到,而SVN難以做到的事情

Git分支功能為強(qiáng)大,分支管理能力讓SVN望塵莫及

Git可以很容易地對(duì)比兩個(gè)分支,知道一個(gè)分支中哪些提交尚未合并到另一分支,反之亦然。

● 查看當(dāng)前分支比other分支多了哪些提交:

    $ git log other..

● 查看other分支比當(dāng)前分支多了哪些提交:

    $ git log ..other

我不認(rèn)為SVN的分支是真正的分支,因?yàn)榉种Щ镜奶峤桓綦xSVN沒(méi)能實(shí)現(xiàn)。 在SVN中一次提交可以同時(shí)更改主線(/trunk)和分支中的內(nèi)容, 所以判斷一個(gè)分支中哪些提交未合并到另外的分支,完全不能對(duì)SVN抱有希望。

Git可以實(shí)現(xiàn)更好的發(fā)布控制

針對(duì)同一個(gè)項(xiàng)目,Git可以設(shè)置不同層級(jí)的版本庫(kù)(多版本庫(kù)), 或者通過(guò)不同的分支(多分支)實(shí)現(xiàn)對(duì)發(fā)布的控制。

● 設(shè)置只有發(fā)布管理員才有權(quán)限推送的版本庫(kù)或者分支,用于穩(wěn)定發(fā)布版本的維護(hù)。

● 設(shè)置只有項(xiàng)目經(jīng)理、模塊管理員才有權(quán)推送的版本庫(kù)或者分支,用用于整合測(cè)試。

上一頁(yè)1234下一頁(yè)
軟件測(cè)試工具 | 聯(lián)系我們 | 投訴建議 | 誠(chéng)聘英才 | 申請(qǐng)使用列表 | 網(wǎng)站地圖
滬ICP備07036474 2003-2017 版權(quán)所有 上海澤眾軟件科技有限公司 Shanghai ZeZhong Software Co.,Ltd