知乎用Go替代Python,是否說明Go比Python好?

来源:https://www.cnblogs.com/qingdeng123/archive/2019/10/19/11705176.html
-Advertisement-
Play Games

編者薦語: 其實我感覺吧。說不上哪個語言會比另一個語言更好。只能說某個語言在某個方面處理某些問題更具有優勢吧。 大概每個開發人員應該都會認為自己使用的語言是世界最好的語言吧。這都相對來說的。對於每個人應該都是不同的。 ​ 眾所周知,知乎早在幾年前就將推薦系統從 Python 轉為了 Go。於是乎,一 ...


編者薦語:

 

其實我感覺吧。說不上哪個語言會比另一個語言更好。只能說某個語言在某個方面處理某些問題更具有優勢吧。

大概每個開發人員應該都會認為自己使用的語言是世界最好的語言吧。這都相對來說的。對於每個人應該都是不同的。

眾所周知,知乎早在幾年前就將推薦系統從 Python 轉為了 Go。於是乎,一部分人就說 Go 比 Python 好,Go 和 Python 兩大社區的相關開發人員為此也爭論過不少,似乎,誰也沒完全說服誰。

 

知乎從Python轉為Go,是不是代表Go比Python好?我認為,各有優點,誰也取代不了誰,會長期共存!

 

“由 Python 語言轉向 Go 語言就說明 Go 語言比 Python 語言好”完全是一種片面理解。

 

“語言至上論”是解決不了業務問題的,選 Go 也不行,Java 也不行。

 

Go 的優勢是文件易部署,協程機制相對成熟且簡單,以及靜態編譯語言的效率,還有就是編程模式相對簡單。這大概是現在越來越多企業嘗試Go的原因,除了知乎,B 站也把核心部件從 PHP 轉到了Go。

 

除此之外,BAT 等互聯網巨頭,內部都有系統採用了 Go 語言。

 

那是不是說 Python、PHP 不行了?當然不是也不應該是這樣的。如果要堅持Python、PHP,也是沒問題。一個系統沉積太久的話,會產生很多大大小小、零零散散的“技術債”,這其間就涉及解決成本的考量,重構、重寫、抑或重新設計核心模塊或新模塊?由此又帶來技術選擇的問題。還有Python、PHP人才儲備的問題,還有團隊希望嘗試新技術的考慮。這些問題交織在一起,就不是哪個編程語言好跟壞這麼簡單的事兒了。所以還是要回到業務層面來看技術解決之道。

 

不得不說,Go的協程,一個“go”就能解決絕大多數問題,確實寫代碼很簡潔,Python 新添的 asyncio 還是相對複雜,Future、Task等等還是有不少門道的。所以,技術永遠只有合適的,而沒有最佳的,也沒有非此即彼的好壞分明。

 

我相信,如果團隊在 Python 方面積累厚實,且熱衷專註於 Python,選擇Python 應該就是個大概率事件。Python 現在已經應用頗廣,特別是在 AI 領域帶動下,Python 人才也不像以前那樣難找工作了,鐵打的營盤流水的兵,是不是知乎也面臨人才流動壓力?此外,畢竟 Python 的生態,在這麼多編程語言中,是數一數二的,Go 雖熱,但在社區方面恐怕還是比不上 Python、PHP,這也是一個現實問題。知乎前端換了 React,我沒感覺比原來的 AngularJS 進步,但不能就此說 React 不行。嘗試用 Go 寫一些原來 Python 的範圍,也是同理。而且一個系統同時應用多種開發語言、一系列技術棧,都是再正常不過的事了。

 

Python 有自己的場景,不會被徹底替換的,擔心也是多慮的,反正都是“增刪改查”嘛!

 

至於,知乎為什麼選擇 Go,內部的一些工程師透露:選擇 Go 並不是一個人的決定,而是整個團隊深思熟慮後的結果!

 

眾所周知,知乎社區後端的主力編程語言是 Python。

 

隨著知乎用戶的迅速增長和業務複雜度的持續增加,核心業務的流量在過去一年內增長了好幾倍,對應的服務端的壓力也越來越大。隨著業務發展,我們發現 Python 作為動態解釋型語言,較低的運行效率和較高的後期維護成本帶來的問題逐漸暴露出來:

 

  1. 運行效率較低。知乎目前機房機櫃空間已經不足,按照目前的用戶和流量增長速度,可預見將在短期內伺服器資源告急(針對這一點,知乎正在由單機房架構升級為異地多活架構);

  2. Python 過於靈活的語言特性,導致多人協作和項目維護成本較高

 

受益於近些年開源社區的發展和容器等關鍵技術的普及,知乎的基礎平臺技術選型一直較為開放。在開放的標準之上,各個語言都有成熟的開源的中間件可供選擇。這使得業務做選型時可以根據問題場景選擇更合適的工具,語言也是一樣。

 

基於此,為瞭解決資源占用問題和動態語言的維護成本問題,我們決定嘗試使用靜態語言對資源占用極高的核心業務進行重構。

 

為什麼選擇 Golang?

 

如上所述,知乎在後端技術選型上比較開放。在過去幾年裡,除了 Python 作為主力語言開發,知乎內部也不乏 Java、Golang、NodeJS 和 Rust 等語言開發的項目。

 

Golang 是當時知乎內部討論交流最活躍的編程語言之一,考慮到以下幾點,知乎決定嘗試用 Golang 重構內部高併發量的核心業務:

 

  1. 天然的併發優勢,特別適合 IO 密集應用

  2. 知乎內部基礎組件的 Golang 版生態比較完善

  3. 靜態類型,多人協作開發和維護更加安全可靠

  4. 構建好後只需一個可執行文件即可,方便部署

  5. 學習成本低,且開發效率較 Python 沒有明顯降

 

相比另一門也很優秀的待選語言—— Java,Golang 在知乎內部生態環境、部署的方便程度和工程師的興趣上都更勝一籌,最終我們決定,選擇 Golang 作為開發語言。

 

最後,我們做個簡單總結:第一點,重構語言的選擇,關鍵要跟公司技術背景和業務場景結合起來;第二點,架構儘量靈活,並不斷自我迭代;第三點,監控要早點開展,並儘可能底層化、通用化。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 系統中的很多頁面有很多公共內容,例如菜單、頁腳等,這些公共內容可以提取放在一個稱為“模板片斷”的公共頁面裡面,其它頁面可以引用這個 “模板片斷”內容。 ...
  • 併發容器 一、ConcurrentHashMap 【1】引入ConcurrentHashMap的目的 ​ ConcurrentHashMap從JDK1.5開始隨java.util.concurrent包一起引入JDK中,主要為瞭解決HashMap線程不安全和Hashtable效率不高的問題。眾所周知 ...
  • 恢復內容開始 盯著電腦工作大半天了,有點疲勞,想想同樣苦逼盯著電腦的女朋友,就想逗逗她緩解一下疲勞。 於是一時手癢,開始了新一輪的騷操作,用Python基於itchat實現微信控制電腦打開攝像頭拍攝當前電腦的使用者並且將圖片發送到你微信上的功能。看到圖片後差點閃瞎我 24k 血輪眼。打碼上圖: 本操 ...
  • import java.util.NoSuchElementException;public class LinkedListT<E> { private Node<E> first; private Node<E> last; long size = 0l; private void linkLa ...
  • 2019-10-19-21:09:31 面向對象的封裝性 封裝性 概念:封裝就是將一些細節信息隱藏起來,對於外界不可見 面向對象封裝性在Java中的體現 1.方法就是一種封裝 2.關鍵字private也是一種封裝 Private關鍵字的使用 why:定義某些類時,無法阻止不合理的數值被設置進來,所以 ...
  • python學習10—迭代器 1. 迭代器協議 對象必須提供一個next方法,執行該方法或者返回迭代中的下一項,或者返回一個StopIteration異常,以終止迭代(只能往後走不能往前退) 2. 可迭代對象 實現了迭代器協議的對象,對象內部定義一個__iter__()方法 3. for迴圈實現機制 ...
  • 前言 什麼是電腦語言 電腦就是一臺用來計算的機器,人讓電腦乾什麼電腦就得乾什麼! 需要通過電腦的語言來控制電腦(也就是編程語言)! 電腦語言其實和人類的語言沒有本質的區別,不同點就是交流的主體不同! 電腦語言發展經歷了三個階段: 1). 機器語言 機器語言通過二進位編碼來編寫程式 執 ...
  • 最近在看一些項目的源碼,總是能學到好多東西。 關於arparse中type的類型指定 不止可以指定常規類型,還可以加一些自己類型判斷,具體用法如下( "來源" ): ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...