自從Facebook的創(chuàng)始人Adam D'Angelo開始效力于這個大量使用了PHP的網(wǎng)站,我就一直在想他要用Python而不是PHP來創(chuàng)造Quora所遇到的技術挑戰(zhàn)。
Adam D'Angelo,Quora創(chuàng)始人:
我們非常確定我們不會用PHP。Facebook因為歷史遺留原因而使用PHP,并不是因為它是最好的選擇。
從以往的經(jīng)驗看來,編程語言的選擇是非常重要的,并且會付出非常昂貴的代價來改變它。
Python是一個Charlie和我都非常了解的語言(盡管我現(xiàn)在比剛開始的時候了解的更多了)。我們也簡單地考慮過C#、Java和Scala,Python最大的問題是運行速度和缺少數(shù)據(jù)類型檢查。
C#似乎是很有前途,作為一個編程語言,它很偉大,但是:
我們不想在微軟架構(gòu)上,我們是為了學習新東西的,MS SQL 確實是非常不錯的,但是我們知道我們需要為.NET集成很多有二等支持的開源代碼,如果它支持的話。并且,現(xiàn)在大部分的工程師都習慣開源資源。
我們不會在Mono(C#/.NET的一個開源代碼的實現(xiàn))上冒險。還不清楚這個項目會用多長時間,并且我還聽說了不少已經(jīng)表現(xiàn)出來的問題??傊坪跻磺性贑#生態(tài)系統(tǒng)中的東西都表現(xiàn)出我們會在微軟架構(gòu)下。
‘另外兩個我們簡要考慮了的語言還有OCaml和Haskkell(沒有一個有足夠大的生態(tài)系統(tǒng)或足夠好的標準庫,可能對于需要寫代碼的設計師/數(shù)據(jù)分析師/非工程師來說太難了)。
我們決定,對于大多數(shù)我們要做的事情來說,Python已經(jīng)足夠快了(因為我們盡可能的把我們的后端服務的關鍵代碼用C++來寫)。至于類型檢查,我們寫了完善的單元測試,它值得寫,并且實現(xiàn)了大部分相同的目標。從它過去的5年發(fā)展來看,Python會繼續(xù)向著好的方向發(fā)展。
所以,我們對于這個選擇感到非常開心。雖然其中有一些小的分歧,但是之前使用其他語言的早期的員工非常高興的過渡到了Python,特別是之前使用PHP的。自從下面這些事情開始發(fā)生:
Python2.6是一個轉(zhuǎn)折點,它有了足夠多的庫進行兼容,我們很容易過渡到它
Tornado(web框架)被發(fā)布為開源,我們把實時更新網(wǎng)絡服務遷移到它上面
PyPy看起來最終是可用的,并且會給我們一個顯著的加速
總之,這些給了我們信心,讓我們相信這個語言和生態(tài)系統(tǒng)正向著好的方向發(fā)展。
Charlie Cheever,Quora的一個創(chuàng)建者
給Adam的答案補充幾件事情:
Python有一堆相當好的提供了良好的調(diào)試器和重載的框架(Django,Pylons和其他一些),這些大部分都被很好的支持并且也變得越來越好。由于我們的主要工作是建設網(wǎng)站,這是很有吸引力的。
Python數(shù)據(jù)機構(gòu)很好的匹配JS數(shù)據(jù)結(jié)構(gòu),所以處理瀏覽器和服務器之間的數(shù)據(jù)非常直接和簡單。這真是太好了,因為Quora中涉及到大量的客戶端和服務端之間的不加載頁面的交互。
Python代碼往往可讀性很強,因為我們希望能在網(wǎng)站上和一幫人工作,這變得非常重要。
有很多其他的Python寫的庫,所以很容易在我們的代碼中引入一些東西,比如:自定義郵件服務器、任務隊列,等等。
Ruby是另一個我認為比較合理的選擇,因為它和Python有很多相同的優(yōu)點,但是Adam和我都對Python了解的更多一點。
-
編程語言
+關注
關注
10文章
1931瀏覽量
34551 -
開源
+關注
關注
3文章
3227瀏覽量
42343 -
python
+關注
關注
55文章
4774瀏覽量
84386
原文標題:為什么Quora選擇Python作為它的開發(fā)環(huán)境?
文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關推薦
評論