基於 Go 語言,鬥魚發佈首個開源框架 Jupiter

IT之家8月6日消息 今年6 月 1 日,鬥魚將基於 Go 語言的微服務框架 Jupiter 正式開源。據悉,Jupiter 脱胎於鬥魚內部的 Golang 微服務框架,歷經多機房建設、雲化、容器化等多次基礎架構演進,基本涵蓋了內部框架的主要功能。

作為國內遊戲直播平台,鬥魚從 2014 年成立至今,在技術上完成了平台自研播放器的開發,優化了直播流的加載速度,針對高併發量、海量數據的處理進行了技術優化,徹底杜絕了當海量用户瞬間湧入平台時無法響應的情況。

Go 語言是由谷歌於 2009 年推出的一門相對比較新的編程語言,因其原生支持高併發的特性,被譽為雲原生時代的容器語言。

從直播角度上來講,若在某個時間點,直播平台能夠承載大量的線上觀看人數而不影響播放品質,説明該平台在出現高併發情況時,優化的比較到位。反之,如果平台未能良好處理大量用户同時湧入的問題,那就會導致服務器宕機。

IT之家獲悉,為了帶來優質且穩定的觀看體驗,鬥魚在 2016 年開始嘗試使用 GO 語言重新編寫後台代碼。鬥魚技術專家 askuy 表示,使用 GO 語言後,平台已經完全可以承受千萬甚至過億級別的併發量。

2018 年,經過多年內部打磨的 Jupiter 框架初步成型,鬥魚武漢技術團隊帶着這套框架在北京研發分部複製,維護成本低、效率高等優點很快讓 Jupiter 在公司內部得到普及,並且受到好評。

儘管 Jupiter 不是最完美的框架,但卻是鬥魚基於多年的實際業務經驗積累起來的。至少在公司內部而言,Jupiter 已經成為最適合鬥魚的微服務架構。

2019 年 9 月 21 日,鬥魚和 GopherChina 在武漢聯合舉辦了 Gopher Meetup 武漢站,吸引了湖北省內大量 Go 語言的研發人員進行了技術交流會。

會議上,鬥魚發現從業者在 Go 語言的使用上依舊存在大量痛點難以解決,而行業內也缺乏相關的成熟框架,於是決定面向所有大眾開源 Jupiter,以此來解決行業普遍存在的微服務生態不完善、維護成本高等問題。

基於 Go 語言,鬥魚發佈首個開源框架 Jupiter

經過了近 1 年的優化調整,鬥魚最終在 6 月 1 日正式開源微服務框架 Jupiter,僅用 1 個半月就收穫了超過 1800 個關注度,並且連續多日霸佔 Github 網站的 golang 熱門開源項目排行榜榜首。

鬥魚表示,目前,Jupiter 現在還處於用户體驗產品的發展階段,希望藉助廣大研發人員的力量,不斷完善這套框架。但未來希望這能夠成為一套成熟的行業規範標準。

版權聲明:本文源自 網絡, 於,由 楠木軒 整理發佈,共 1040 字。

轉載請註明: 基於 Go 語言,鬥魚發佈首個開源框架 Jupiter - 楠木軒