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