在大學(xué)的時候,就聽說了阿里、美團(tuán)、京東系是 Java 一派,只有鵝廠獨樹一幟,以 C/ C++ 為后臺開發(fā)主力語言。
這是為啥咧?我也很想知道!
為啥選擇 C++
其實原因呢,我猜也很簡單:
一方面是慣性使然,任何一個公司都是有技術(shù)棧積累的。
鵝廠在長期使用 C++ 的過程中,開發(fā)了大量基于 C++ 的內(nèi)部組件可以使用, KV存儲、RPC、微服務(wù)框架等等一應(yīng)俱全。
并且都有專門的團(tuán)隊維護(hù)和經(jīng)過生產(chǎn)環(huán)境考驗的,可以 C++ 組件很豐富也很穩(wěn)定。
整個團(tuán)隊也是更加熟悉 C++,沒有理由也沒有動力去切其它語言,所以就一直在 C++ 的道路上越走越遠(yuǎn)。
另一方面就是兩類公司的基因不太一樣,怎么說?
鵝廠早期是做尋呼機起步的,后來又做了 QQ,可以看出都是和網(wǎng)絡(luò)、通信相關(guān)的一些軟件,這類基本都是 C/C++ 開發(fā)。
我記得 QQ 自誕生之時起,用戶便呈拋物線增長,為此 QQ 后臺服務(wù)器多次瀕臨極限,耗費的服務(wù)器巨額增長。
當(dāng)時的騰訊還不怎么賺錢,用 C/C++ 在性能上更高,相同服務(wù)器數(shù)量能支撐的用戶量應(yīng)該也是大不少的,所以后來應(yīng)該就沿用下來了吧。
后面又進(jìn)入游戲行業(yè),而游戲是對延時特別敏感的,所以一般都是用 C++。
而阿里早期是做黃頁起步的,據(jù)說當(dāng)時還是 PHP,后來做電商才切到 Java 的,淘寶、美團(tuán)這類 toB 業(yè)務(wù)的特點就是復(fù)雜,一般選擇 Java 的都比較多。
用 C++ 怎么寫后臺?
在學(xué)校學(xué) C++ 的時候,我就很好奇 C++ 寫后臺服務(wù)到底是什么樣的?
因為 C++ 沒有一個完善的開源生態(tài)...... 不像 Java、Node、PHP、Flask 這些語言,都有對應(yīng)的 Web 框架,學(xué)完語言就能用框架寫個后臺服務(wù)。
但是 C++ 實在不知道該怎么寫,寫也只是 解析靜態(tài)的 HTTP 協(xié)議的 WebServer 而已。
去年來騰訊實習(xí)之后,我才知道這些大廠都是怎么用 C++ 構(gòu)建的后臺服務(wù)。
由于小北在微信,所以這里就以微信的技術(shù)棧為例了,聊聊在微信用 C++ 做后臺開發(fā)是一種什么樣的體驗?
體驗很像 Java!
是的,開發(fā)起來的效率和感覺是無比接近 Java 的,這得益于那些大佬寫的基礎(chǔ)組件很完善。
微信后臺開發(fā)體驗
微信后臺主要使用 C++,后臺服務(wù)使用 Svrkit 框架搭建,服務(wù)之間通過同步 RPC 進(jìn)行通訊,這個在百度上也是能搜到一些信息的。
圖源:infoQ
Svrkit 主要是用于開發(fā)后臺微服務(wù)的框架,基本上開發(fā)三部曲:
- 制定通信協(xié)議,定義 proto 文件
- 用命令基于這個 proto 文件生成服務(wù)框架代碼
- 填充處理業(yè)務(wù)邏輯的函數(shù)(服務(wù))
是不是很像 SpringBoot 這類框架?基本上,業(yè)務(wù)只需要關(guān)注數(shù)據(jù)模型設(shè)計、數(shù)據(jù)存儲、通信,然后就是實現(xiàn)具體的業(yè)務(wù)邏輯了。
框架會自動幫你完成打解包、網(wǎng)絡(luò)通信、失敗重試等微服務(wù)框架應(yīng)該做的事。
這是后臺 RPC 服務(wù)的開發(fā),但是我們知道,對外的接口一般都是用 HTTP 的,所以這里需要用一層接入層做一些協(xié)議轉(zhuǎn)換和參數(shù)、簽名校驗等工作。
這一層一般叫做 CGI(估計也只有鵝廠還喜歡叫 CGI 吧?),CGI 可以用 PHP 開發(fā),也可以用 C++ 寫,這一層的目的就是對外提供 HTTP(一般是 JSON)訪問接口,然后調(diào)用后臺 RPC 服務(wù)(protobuf)。
當(dāng)然,微信客戶端和后臺 RPC 服務(wù)之間就是走微信的自定義協(xié)議了。
所以,其實和 Java 在開發(fā)效率上沒什么明顯區(qū)別。
當(dāng)然了,鵝廠也不是所有都是 C++ 開發(fā),幾乎主流的后臺語言,都會有不同的團(tuán)隊在使用,尤其是一些新業(yè)務(wù),沒有歷史負(fù)債的,也會用 Go、Java 等。
但是微信后臺幾乎是 C++ 主導(dǎo),所以想來微信做后臺的同學(xué)可以學(xué)下 C++ ,雖然說校招不會限制語言,但是 C++ 使用熟練總算是個加分項吧。
在微信,很多后臺開發(fā)的組件都是自研的,比如存儲用的KV(MySQL用的比較少)、消息隊列、RPC 框架等。
這些學(xué)習(xí)上手都是很快的,畢竟技術(shù)思想都是通用的,只是換個實現(xiàn)形式、調(diào)用接口而已。
如果想體驗 C++ 開發(fā)后臺服務(wù)的同學(xué),可以去看下搜狗開源的 srpc,包括百度 brpc、Google grpc 都是這樣的,用起來很相似。
免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!