版本控制工具歷史的10個里程碑

導讀:作者Eric Raymond在flourish上發表的一篇《Astonishments, ten, in the history of version control》,文中總結了版本控制工具的重要10個里程碑,一起與開發者分享下。

如果你想要了解真正的歷史,你需要回到在打孔卡上進行人工比對的年代。” —— Jim Rootham

在這個為鱈魚編寫傳記都能夠流行的年代,寫一本記錄程序員如何存儲代碼——他們最重要的勞動成果的書一點也不瘋狂。

既然你和我都沒有時間來閱讀或編寫這樣的一本書,我們打算用這篇博客來進行探討。

這是一個重要的問題。

(現在)版本控制產品非常普通而且很流行。然而,它經歷了幾十年的不斷創新。在這個領域里最聰明的人的努力下,代碼管理變得非常簡單而且有效。

每一步都是那么讓人感到驚奇。

1. 源代碼就是一個文本文件!(20世紀60年代)

現在看來,存儲源代碼和編寫簡單文檔應該是一樣的。但如果你簡單讀一下ASCII的歷史就會知道,即使達成這樣的共識也來之不易。

2. 人們可以手動跟蹤代碼版本!(20世紀60年代)

在沒有軟件的年代,所有事情都要從源代碼開始。

“我工作的第一家公司有一個源碼管理部門。當你把代碼寫好以后,將軟盤交給源碼管理部門一位漂亮女士。他們會及時更新函數庫,用你的磁盤基于公司官方的代碼構建產品交付給客戶。” ——? Miles Duke

3. 你可以為單個文件保留多個版本!(1972,1978)

采用奇特的交錯編織文件格式,SCCS在版本控制領域稱雄了10年之久。

記錄單個文件的從一個版本到下一個之間的變化花費了幾年的時間。“差異文件比較算法”是這個課題最近發表的一篇論文(1976)。

1982年,RCS反向使用diff文件(描述算法原文)打敗了SCCS成為繼任者,并讓評論家大跌眼鏡:

“一起出現的還有帶有反向比較功能的RCS,我認為它非常棒。” —— 無名氏

4. 每個人都可以檢出自己的拷貝!(1982)

在那個時候,人們工作時需要登錄一臺中央大型機并通過它一起工作。采用符號鏈接,RCS可以讓每個人都工作在相同版本的代碼上,而且每個人都有自己的工作拷貝。

“有一個叫做RCS的文件,實際上它十一個鏈接到RCS倉庫的符號鏈接,你可以與其他小組成員一起使用。”? —— 耶魯大學RCS使用介紹

5. 喔!你可以一次給多個文件進行版本控制!(1986)

令人吃驚的是,直到CVS出現之前,版本控制系統都只支持單個文件。當然,你可以使用通配符讓RCS提交多個文件或者標記特定分支。但這些并不是版本控制系統的一部分。

CVS默認會遞歸修改所有文件。突然之間,軟件從單個目錄或文件變成了文本文件的遞歸樹。

雖然由于不具備“原子性”導致實現的產品不盡如人意(后來Subversion在2000年解決了這個問題),但是瑕不掩瑜。

6. 兩個人可以同時編輯同一個文件,并將他們的工作合并在一起!(1986)

20世紀90年代末,我在Creature Labs工作。我們從Visual SourceSafe(商業軟件,微軟公司發布)轉到CVS(開源軟件,由一些嘻皮士發布)。

坦率的講,大家都懷疑CVS能否做到它宣稱的那樣:讓多個人同時編輯同一個文件,并將他們的修改沒有錯誤地合并到一起而不造成其他問題。

在我們開發Creatures 3的時候,SourceSafe的互斥鎖成為了一個大問題。我們當時要添加垃圾搜集功能,這個功能會影響到幾乎所有的代碼。這個時候,我們的首席程序員不得不在周末檢出每一個文件然后進行修改。

1986年的這篇論文記錄下了這個奇跡。當Dick Grune和他的團隊在荷蘭開發一個編譯器的時候,他們遇到了同樣的問題,CVS從此應運而生。

7. 可以在遠程服務器上共享代碼倉庫!(1994)

大多數時候,人們只在一臺機器上使用版本控制。在1986年,人們可以通過RCS的一些版本以及CVS提供的遠程文件共享機制以擁有遠程代碼倉庫。

“假如RCS的某個版本可以通過遠程服務器訪問,那么開發人員就可以在代碼倉庫之外的機器上進行開發了。”? —— Dick Grune

然而,直到1994年TCP/IP協議的引入,這個想法才得以起步。

“直到Cygnus軟件的Jim Blandy和Karl Fogel(這兩位后來成為Subversion項目的主要開發者)為CVS發布了一些補丁,使得CVS客戶端軟件可以通過遠程TCP/IP連接進行訪問,CVS才真正變得無處不在。 ”—— Eric Raymond

8. 免費的開源版本控制主機服務!(1999)

這并不是源碼管理技術的進步,但這的確是一個標志,Internet社區的發展與技術的進步同等重要:

“OSS以及成為歷史,這已經成為一種趨勢。John T. Hall 預見到,如果項目都是在線開發,那么之前開發的版本就在那里。開發平臺服務是一種創新,但是沒有人去做,我們就想‘為什么不呢?’”—— Brian Biles

就像末日狂歡那樣(因為股票的原因),VA Linux把SourceForge帶到了這個世界上。這對新項目是天大的好消息(例如我的TortoiseCVS)。

在當時,在Internet上獲得一臺服務器很困難而且非常昂貴,進行源碼管理和bug追蹤也是如此。這項新服務盡管缺乏商業模式,卻讓無數項目更早地面世。(譯注:OSS:一個綜合的業務運營和管理平臺,同時也是真正融合了傳統IP數據業務與移動增值業務的綜合管理平臺。)

9. 沒有主代碼庫,你可以向所有人發布!(2005)

在21世紀頭10年,有一股將版本控制實現完全分布式的潮流。

也就是說,在你本地的機器上存放的是一份完整的代碼歷史,可以輕易地與任何其他拷貝進行分支和合并。順帶說一下,也正是這個特性使得分支和合并變得更加容易。

我并沒有記錄某個第一次發明這種工具,而是按照它產品化以及流行的時間進行統計。鑒于此,將它定在2005年似乎有些不公平。Mercurial和Git發布于2005年4月。

這篇“分布式版本控制風險”(2005年底)介紹了這個革命性的創新。

10. 當你檢出一個fork,你可以讓大家都看到!(2008)

GitHub的成功有很多原因(盡管我之前提到過一些,要講清楚這個問題還是需要單獨寫一篇文章討論)。

關鍵在于,你可能甚至可以將一些自己做的不大的改動提交到別人的公共代碼上。在GitHub之前,一般我們會保存在自己的電腦上。

如今,只需要簡單做一個fork,或者甚至可以直接在瀏覽器上編輯,這樣任何人都可以馬上發現你代碼中的bug。

尾聲

快速回顧一下這幾十年的進展。是的,計算機的發展做出了貢獻。但更主要的是,這些都是人們為更好地協作而貢獻出的聰明才智。這讓我想到,下一個會是什么?在版本控制領域還會有什么令人驚嘆的事情發生?

推而廣之,同樣的事情會在其它領域發生嗎?作為核心信息基礎設施,這種巨大的改進能夠最終改善政府、醫療、新聞或者數據領域創新的障礙嗎?

我有這種感覺,我們就要找到答案了。

文章出自:flourish

譯文出自:伯樂在線


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/452652.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/452652.shtml
英文地址,請注明出處:http://en.pswp.cn/news/452652.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

php把語音轉成幀,[轉載]用TCP/IP實現自己簡單的應用程序協議:成幀器部分

在前面《字節和字符,對信息進行編碼》,《Socket>流,TCP連接,TCP可靠性概述》一系列的隨筆中我們已經表述了相應的理論知識,現在可以動手實現一個自己的應用程序協議。將 數據轉換成在線路上傳輸的字節序列只完成了一半的工作,在…

實體聯系圖簡介

通常,使用實體聯系圖(entity relationship diagram)來建立數據模型。可以把實體聯系圖簡稱為ER圖,相應地可把用ER圖描繪的數據模型稱為ER模型。 ER圖中包含了實體(即數據對象)、關系和屬性3種基本成分,通常用矩形框代表實體,用連…

Flask愛家租房--城區信息

0.效果展示 城市列表使用緩存的過程 1.后端代碼 # coding:utf-8from . import api from flask import g, current_app, jsonify, request, session from ihome.utils.response_code import RET from ihome.models import Area, House, Facility, HouseImage, User, Order from …

數值計算算法-多項式插值算法的實現與分析

數值計算是指在數值分析領域中的算法。數值分析是專門研究和數字以及近似值相關的數據問題,數值計算在數值分析的研究中發揮了特別重要的作用。 多項式插值是計算函數近似值的一種方法。其中函數值僅在幾個點上已知。 該算法的基礎是建立級數小于等于n的一個插值多項…

HIVE ORC 報錯ClassCastException

HIVE ORC格式的表查詢報錯 Failed with exception java.io.IOException:java.lang.ClassCastException: org.apache.hadoop.hive.ql.io.orc.OrcStruct cannot be cast to org.apache.hadoop.io.BinaryComparable 建表語句如下: CREATE EXTERNAL TABLE test_orc( te…

程序型語言VS.編譯型語言

導讀:每日[快訊精選]是由CSDN研發頻道推出的特色欄目,每一天我們將從國外技術媒體(例如Hacker News、Reddit...等等)中挑選出有價值的新聞簡訊,讓您在第一時間掌握業界主流的技術文摘,每天清晨為您獻上第一份技術早餐。 [1]程序型…

ancestral 箭頭符號,譯林版《牛津高中英語》模塊五 高二上學期

《牛津英語》由譯林出版社和牛津大學出版社聯合編寫出版。通過在南京和蘇州開始的試用,取得了非常良好的效果,己在省內全面推廣。有人認為新教材在教育觀念和編排體系上的改革力度是八十年代以來最大的一次。它帶給我們一線教師的沖擊無疑是巨大的。二、…

[NOI2012]騎行川藏

題解: 我發現拉格朗日乘數法真是個好東西。。 我是不會說我數學競賽求最值都是用這個東西的 由于我不太會打那個符號就用li代表通常偏導數中的lanmuda 。。。 這題里化簡一下就可以得到 2 li * ki * ?(vi??vi′?)* vi^2?1 然后一旦li確定 我們會發現這個三次函…

MAC地址和IP地址的關系

簡單地說:ip地址是服務商給你的,mac地址是你的網卡物理地址。 一、IP地址 對于IP地址,相信大家都很熟悉,即指使用TCP/IP協議指定給主機的32位地址。IP地址由用點分隔開的4個8八位組構成,如192.168.0.1就是一個IP地址…

Linux中斷 - tasklet

一、前言 對于中斷處理而言,linux將其分成了兩個部分,一個叫做中斷handler(top half),屬于不那么緊急需要處理的事情被推遲執行,我們稱之deferable task,或者叫做bottom half,。具體…

數字電視制播設備間的文件交換格式

在現今的數字電視演播室中,設備之間基本上采用信號流連接方式,如SDI、STDI、模擬YUV、VBS等信號流。在非線性編輯系統和播出系統與服務器之間的連接,還有基于MPEG-2傳輸流等的信號連接方式。基于信號流連接方式的主要特點是,傳送時…

oracle 位移運算符,Oracle“(+)”運算符

在Oracle中,()表示JOIN中的“可選”表。 所以在你的查詢中,select a.id, b.id, a.col_2, b.col_2, ... from a,b where a.idb.id()這是一個左外加B表與一個表。 就像現代的左連接查詢一樣。 (它將返回a表的所有數據,而不會丟失在另一邊的數據…

JAVA-數據類型-復習

JAVA-數據類型-復習 Java中,一共有8種數據類型,4種整型,2種浮點型,1種用于表示Unicode編碼的字符單元的字符類型char,1種布爾類型。 整型 類型存儲需求(字節)一個字節包含8個位取值范圍byte1-12…

什么是實體-聯系圖(ER圖)

實體-聯系圖(ER圖)數據模型中包含3種相互關聯的信息:數據對象、數據對象的屬性及數據對象彼此間相互連接的關系。 1.數據對象 數據對象是對軟件必須理解的復合信息的抽象。所謂符合信息是指具有一系列不同性質或屬性的事物,僅有單…

記錄的習慣

記錄的習慣 書籍是人類進步的階梯,承載了人類文明進步的歷程。大多數人都寫過日記,但不知道有多少人重視過日記。常常我們會用相機記錄一些生活中的場景,然后收藏起來,等到若干年后再拿出來看,總能感覺到很溫馨很美好。…

php 去掉實體,用PHP刪除除5個預定義HTML實體之外的所有實體的最佳方法-用于XHTML5輸出...

我目前正在嘗試提供XHTML5.目前,我在正在處理的頁面上提供XHTML 1.1 Strict.那就是我為有能力的瀏覽器所做的.對于那些不接受XML編碼數據的人,我會嚴格遵循HTML4.1.在嘗試使用HTML5進行試驗時,以HTML5格式交付時,所有功能或多或少都可以按預期工作.但是,作為XHTML5交付時,我遇到…

Flask愛家租房--發布新房源(保存房屋基本信息)

0.頁面展示效果 1.后端代碼 api.route("/houses/info", methods["POST"]) login_required def save_house_info():"""保存房屋的基本信息前端發送過來的json數據{"title":"","price":"","ar…

今后最有前途的媒體格式 MXF

MXF格式已經被推出幾年了,從當初一個陌生的不為人們重視的格式逐漸獲得了業內人士的認知和認可,現如今正被廣泛應用于廣播電視與后期制作領域,且有不斷擴大之勢,松下公司推出的基于PII卡的無磁帶式標清攝像機,它所采用…

【c#】RabbitMQ學習文檔(一)Hello World

一、簡介 RabbitMQ是一個消息的代理器,用于接收和發送消息,你可以這樣想,他就是一個郵局,當您把需要寄送的郵件投遞到郵筒之時,你可以確定的是郵遞員先生肯定會把郵件發送到需要接收郵件的人的手里,不…