您好,登錄后才能下訂單哦!
這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)知乎從Python轉(zhuǎn)為Go的原因,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
大概每個(gè)開發(fā)人員應(yīng)該都會認(rèn)為自己使用的語言是世界最好的語言吧。這都相對來說的。對于每個(gè)人應(yīng)該都是不同的。
眾所周知,知乎早在幾年前就將推薦系統(tǒng)從 Python 轉(zhuǎn)為了 Go。于是乎,一部分人就說 Go 比 Python 好,Go 和 Python 兩大社區(qū)的相關(guān)開發(fā)人員為此也爭論過不少,似乎,誰也沒完全說服誰。
知乎從Python轉(zhuǎn)為Go,是不是代表Go比Python好?我認(rèn)為,各有優(yōu)點(diǎn),誰也取代不了誰,會長期共存!
“由 Python 語言轉(zhuǎn)向 Go 語言就說明 Go 語言比 Python 語言好”完全是一種片面理解。
“語言至上論”是解決不了業(yè)務(wù)問題的,選 Go 也不行,Java 也不行。
Go 的優(yōu)勢是文件易部署,協(xié)程機(jī)制相對成熟且簡單,以及靜態(tài)編譯語言的效率,還有就是編程模式相對簡單。這大概是現(xiàn)在越來越多企業(yè)嘗試Go的原因,除了知乎,B 站也把核心部件從 PHP 轉(zhuǎn)到了Go。
除此之外,BAT 等互聯(lián)網(wǎng)巨頭,內(nèi)部都有系統(tǒng)采用了 Go 語言。
那是不是說 Python、PHP 不行了?當(dāng)然不是也不應(yīng)該是這樣的。如果要堅(jiān)持Python、PHP,也是沒問題。一個(gè)系統(tǒng)沉積太久的話,會產(chǎn)生很多大大小小、零零散散的“技術(shù)債”,這其間就涉及解決成本的考量,重構(gòu)、重寫、抑或重新設(shè)計(jì)核心模塊或新模塊?由此又帶來技術(shù)選擇的問題。還有Python、PHP人才儲備的問題,還有團(tuán)隊(duì)希望嘗試新技術(shù)的考慮。這些問題交織在一起,就不是哪個(gè)編程語言好跟壞這么簡單的事兒了。所以還是要回到業(yè)務(wù)層面來看技術(shù)解決之道。
不得不說,Go的協(xié)程,一個(gè)“go”就能解決絕大多數(shù)問題,確實(shí)寫代碼很簡潔,Python 新添的 asyncio 還是相對復(fù)雜,F(xiàn)uture、Task等等還是有不少門道的。所以,技術(shù)永遠(yuǎn)只有合適的,而沒有最佳的,也沒有非此即彼的好壞分明。
我相信,如果團(tuán)隊(duì)在 Python 方面積累厚實(shí),且熱衷專注于 Python,選擇Python 應(yīng)該就是個(gè)大概率事件。Python 現(xiàn)在已經(jīng)應(yīng)用頗廣,特別是在 AI 領(lǐng)域帶動下,Python 人才也不像以前那樣難找工作了,鐵打的營盤流水的兵,是不是知乎也面臨人才流動壓力?此外,畢竟 Python 的生態(tài),在這么多編程語言中,是數(shù)一數(shù)二的,Go 雖熱,但在社區(qū)方面恐怕還是比不上 Python、PHP,這也是一個(gè)現(xiàn)實(shí)問題。知乎前端換了 React,我沒感覺比原來的 AngularJS 進(jìn)步,但不能就此說 React 不行。嘗試用 Go 寫一些原來 Python 的范圍,也是同理。而且一個(gè)系統(tǒng)同時(shí)應(yīng)用多種開發(fā)語言、一系列技術(shù)棧,都是再正常不過的事了。
Python 有自己的場景,不會被徹底替換的,擔(dān)心也是多慮的,反正都是“增刪改查”嘛!
至于,知乎為什么選擇 Go,內(nèi)部的一些工程師透露:選擇 Go 并不是一個(gè)人的決定,而是整個(gè)團(tuán)隊(duì)深思熟慮后的結(jié)果!
眾所周知,知乎社區(qū)后端的主力編程語言是 Python。
隨著知乎用戶的迅速增長和業(yè)務(wù)復(fù)雜度的持續(xù)增加,核心業(yè)務(wù)的流量在過去一年內(nèi)增長了好幾倍,對應(yīng)的服務(wù)端的壓力也越來越大。隨著業(yè)務(wù)發(fā)展,我們發(fā)現(xiàn) Python 作為動態(tài)解釋型語言,較低的運(yùn)行效率和較高的后期維護(hù)成本帶來的問題逐漸暴露出來:
運(yùn)行效率較低。知乎目前機(jī)房機(jī)柜空間已經(jīng)不足,按照目前的用戶和流量增長速度,可預(yù)見將在短期內(nèi)服務(wù)器資源告急(針對這一點(diǎn),知乎正在由單機(jī)房架構(gòu)升級為異地多活架構(gòu));
Python 過于靈活的語言特性,導(dǎo)致多人協(xié)作和項(xiàng)目維護(hù)成本較高
受益于近些年開源社區(qū)的發(fā)展和容器等關(guān)鍵技術(shù)的普及,知乎的基礎(chǔ)平臺技術(shù)選型一直較為開放。在開放的標(biāo)準(zhǔn)之上,各個(gè)語言都有成熟的開源的中間件可供選擇。這使得業(yè)務(wù)做選型時(shí)可以根據(jù)問題場景選擇更合適的工具,語言也是一樣。
基于此,為了解決資源占用問題和動態(tài)語言的維護(hù)成本問題,我們決定嘗試使用靜態(tài)語言對資源占用極高的核心業(yè)務(wù)進(jìn)行重構(gòu)。
為什么選擇 Golang?
如上所述,知乎在后端技術(shù)選型上比較開放。在過去幾年里,除了 Python 作為主力語言開發(fā),知乎內(nèi)部也不乏 Java、Golang、NodeJS 和 Rust 等語言開發(fā)的項(xiàng)目。
Golang 是當(dāng)時(shí)知乎內(nèi)部討論交流最活躍的編程語言之一,考慮到以下幾點(diǎn),知乎決定嘗試用 Golang 重構(gòu)內(nèi)部高并發(fā)量的核心業(yè)務(wù):
·天然的并發(fā)優(yōu)勢,特別適合 IO 密集應(yīng)用
·知乎內(nèi)部基礎(chǔ)組件的 Golang 版生態(tài)比較完善
·靜態(tài)類型,多人協(xié)作開發(fā)和維護(hù)更加安全可靠
·構(gòu)建好后只需一個(gè)可執(zhí)行文件即可,方便部署
·學(xué)習(xí)成本低,且開發(fā)效率較 Python 沒有明顯降
相比另一門也很優(yōu)秀的待選語言—— Java,Golang 在知乎內(nèi)部生態(tài)環(huán)境、部署的方便程度和工程師的興趣上都更勝一籌,最終我們決定,選擇 Golang 作為開發(fā)語言。
最后,我們做個(gè)簡單總結(jié):第一點(diǎn),重構(gòu)語言的選擇,關(guān)鍵要跟公司技術(shù)背景和業(yè)務(wù)場景結(jié)合起來;第二點(diǎn),架構(gòu)盡量靈活,并不斷自我迭代;第三點(diǎn),監(jiān)控要早點(diǎn)開展,并盡可能底層化、通用化。
上述就是小編為大家分享的知乎從Python轉(zhuǎn)為Go的原因了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。