欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Go 微服務(wù)開發(fā)框架DMicro設(shè)計思路詳解

 更新時間:2022年10月19日 16:47:03   作者:退休程序猿  
這篇文章主要為大家介紹了Go 微服務(wù)開發(fā)框架DMicro設(shè)計思路詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

背景

DMicro 誕生的背景,是因為我寫了 10 來年的 PHP,想在公司內(nèi)部推廣 Go, 公司內(nèi)部的組件及 rpc 協(xié)議都是基于 swoole 定制化開發(fā)的。調(diào)研了市面上的各種框架,包括 beego,goframe,gin,go-micro,go-zero,erpc 等等,可能是我當(dāng)時技術(shù)能力有限,并不能讓這些框架很好的適配我們的業(yè)務(wù)。

我們業(yè)務(wù)開發(fā)有幾個痛點,在當(dāng)時 golang 的生態(tài)中無法找到一整套解決方案。

  • 微服務(wù)應(yīng)用和單體應(yīng)用同時開發(fā)。
  • 高性能,高可用的網(wǎng)絡(luò)通訊。
  • 需要自定義應(yīng)用層的協(xié)議 (重點)。
  • 需要靈活的插件擴展機制,方便適配現(xiàn)有系統(tǒng) (重點)。
  • 服務(wù)端與客戶端的概念模糊,互相都能使用相同的 api 調(diào)用對方。
  • 支持 Push 消息。
  • 連接 / 會話管理。
  • 高效率的開發(fā),支持通過 proto 生成代碼。
  • 支持多種網(wǎng)絡(luò)協(xié)議,tcp,websocket,quic,unixsocket.
  • 兼容 http 協(xié)議。
  • 能夠更快速的定位問題。
  • 更便捷的增加新特性。

在對常用的開源框架做了簡單的調(diào)研以后,發(fā)現(xiàn)并沒有一款合適的框架能滿足我的所有需求。在認(rèn)真思考過后,發(fā)現(xiàn) erpc 和 goframe 兩個框架的結(jié)合體能滿足我的需求,于是就誕生了自研 DMicro.

概述

DMicro 中的 drpc 組件的思想是參考 erpc 實現(xiàn),甚至可以說是它的繼承者。

drpc 組件是 DMicro 框架的一部分,為了適配 DMicro 框架,在 erpc 的基礎(chǔ)上做了深入的擴展開發(fā)。

整個 DMicro 大量使用 goframe 中的組件,如果業(yè)務(wù)使用 goframe 框架,可以無縫接入。

DRpc 特性列表:

  • 對等通信 , 對等Api
  • 高性能 , 非阻塞異步IO
  • 自定義Proto,, 兼容http協(xié)議 , 自定義Codec
  • Hook點 , 插件系統(tǒng) ,
  • Push消息 ,session管理,Socket抽象 ,
  • 斷線重連 , 過載保護 , 負(fù)載均衡 , 心跳機制 ,
  • 平滑重啟 ...

DServer 特性列表:

  • 快速構(gòu)建 , 平滑重啟 , 多進程支持 , 單/多進程一致
  • 預(yù)定義命令行 ,ctrl命令管理服務(wù)
  • 可觀測 , 可控制 , 應(yīng)用沙盒

DMicro 已經(jīng)內(nèi)置組件:

  • [x] Registry 服務(wù)注冊
  • [x] Selector 服務(wù)發(fā)現(xiàn)
  • [x] Eventbus 事件總線
  • [x] Supervisor 進程管理
  • [ ] Code gen 代碼生成
  • [ ] Tracing 鏈路追蹤
  • [ ] Metrics 統(tǒng)計告警
  • [ ] Broker 限流熔斷
  • [ ] OpenAPI 文檔自動生成

架構(gòu)

設(shè)計理念

對 DMicro 框架的設(shè)計,從設(shè)計之初就是在追求靈活性,適應(yīng)性。在保證微服務(wù)的穩(wěn)定性前提下,追求項目的開發(fā)效率。

  • 面向接口設(shè)計,保證代碼穩(wěn)定,提供靈活定制。
  • 抽象各組件的接口,高內(nèi)聚,低耦合。
  • 分層設(shè)計,自上而下逐層封裝,利于穩(wěn)定和維護。
  • 高性能,高可用,低消耗。
  • 對開發(fā)友好,封裝復(fù)雜度。
  • 提供豐富的組件及功能,讓開發(fā)專注業(yè)務(wù)。

無數(shù)個寫 DMicro 的日夜,我都謹(jǐn)記開發(fā)三原則:

  • Clarity(清晰)
  • Simplicity(簡單)
  • Productivity(生產(chǎn)力)

無論工作,還是做開源項目,都應(yīng)該保持這三個原則,養(yǎng)成良好的習(xí)慣。

面向接口設(shè)計

DMicro 秉承著萬物皆接口的原則,提供框架無與倫比的擴展性.

下圖展示的是消息的發(fā)送的流轉(zhuǎn)流程,可以看到,所有的功能點都被抽象成了接口,每個功能點都提供了不同的實現(xiàn).

會話 Session

大多數(shù)的 Rpc 框架并不強調(diào)會話 (session) 的概念,因其應(yīng)用場景不需要用到會話 (session). 那么 drpc 為什么需要抽象出會話 (session) 呢?

  • Endpoint 融合了 Client 和 Server, 需要提供相同的 Api.
  • 服務(wù)端需要主動向客戶端發(fā)送消息,并且獲取客戶端的響應(yīng).
  • 服務(wù)端支持對多個客戶端批量發(fā)送消息.
  • 異步主動斷開一個或多個會話.
  • 獲取會話底層的文件描述符 , 對其進行性能調(diào)優(yōu).
  • 可以為每個會話綁定特殊的數(shù)據(jù)/屬性.

Session 抽象了整個 drpc 框架的會話,把 Socket,Message,Context 都融合到一起。開發(fā)者只需要對 session 進行操作,就能實現(xiàn)大多數(shù)需求.

  • 獲取連接信息
  • 控制連接的生命周期 (超時時間)
  • 控制單次請求的生命周期 (超時時間)
  • 接收消息
  • 發(fā)送消息
  • 創(chuàng)建消息的上下文
  • 綁定會話的相關(guān)信息 (如用戶信息)
  • 斷線重連
  • 主動斷開會話.
  • 健康檢查
  • 獲取連接關(guān)閉事件
  • 為會話設(shè)置單獨的 id

Session 接口可以細(xì)分為 4 個 interface{}, 分別是 EarlySession,BaseSession,CtxSession,Session. 對應(yīng)的是應(yīng)用的不同生命階段會話 (Session) 擁有的不同屬性.

  • EarlySession 表示剛生成會話,尚未啟動 goroutine 讀取數(shù)據(jù)的階段.
  • BaseSession 只有最基礎(chǔ)的方法,用于關(guān)閉連接時候的插件參數(shù).
  • CtxSession 在處理程序上下文中傳遞的會話對象.
  • Session 全功能的會話對象.

正常情況下,開發(fā)者用到的都是 Session,CtxSession 這兩個接口,其他 2 個接口是在插件中使用.

消息 Message

消息 Message 包含消息頭 Header, 消息體 Body, 是客戶端與服務(wù)端之間通信的實體.

Message interface{} 抽象了對通信實體的操作.

  • Size 消息的長度
  • Transfer-Filter-Pipeline 報文數(shù)據(jù)過濾處理管道
  • Seq 序列號
  • MType 消息類型
  • ServiceMethod 資源標(biāo)識符
  • Meta 消息的元數(shù)據(jù)
  • BodyCodec 消息體編碼格式
  • Body 消息體

協(xié)議 Proto

協(xié)議是對消息Message 對象的序列化和反向序列化,框架提供 Proto 接口。只需要實現(xiàn)該接口,開發(fā)者就能定制符合業(yè)務(wù)需求的自定義協(xié)議,從而提升了框架的靈活性.

接口的定義如下:

type Proto interface {
	Version() (byte, string)
	Pack(Message) error
	Unpack(Message) error
}
  • Version() 返回該協(xié)議的 id 和名字,兩個組成唯一的版本號.
  • Pack 對消息 Message 對象進行序列化.
  • Unpack 對字節(jié)流反序列化,生成一個消息 Message 對象.

目前框架已支持 Http,Json,Raw,Protobuf,JsonRpc 這 5 個協(xié)議.

RAW 協(xié)議組成如下:

其他協(xié)議可以參考代碼.

編碼 Codec

作為一個通用性的框架,支持的協(xié)議可以有多種,消息體的編解碼也可以有多少種. drpc 使用 Codec 接口對消息體 Body 進行編解碼.

接口的定義如下:

type Codec interface {
	ID() byte
	Name() string
	Marshal(interface{}) ([]byte, error)
	Unmarshal([]byte, interface{}) error
}
  • ID 返回編 Codec 的 id
  • Name 返回編 Codec 的名字,名字是為了開發(fā)者更容易識別.
  • Marshal 對消息內(nèi)容進行編碼
  • Unmarshal 對消息內(nèi)容進行解碼

目前框架已支持 Form,Json,plain,Protobuf,XML 這 5 個編解碼.

連接 Socket

Socket 擴展了 net.Conn, 并且抽象出接口,方便框架對底層網(wǎng)絡(luò)協(xié)議的集成.

Socket 接口實現(xiàn)了一部分 Session 接口的功能,Session 接口調(diào)用的一些方法,實際上是轉(zhuǎn)發(fā)調(diào)用了 Socket 中的方法.

這樣的分層實現(xiàn),讓 Socket 擁有的集成其他協(xié)議的能力.

  • TCP V4,TCP V6
  • Unix Socket
  • KCP
  • QUIC

支持對連接的性能調(diào)優(yōu).

  • SetKeepAlive 開啟鏈接保活
  • SetKeepAlivePeriod 鏈接?;铋g隔時間
  • SetReadBuffer 設(shè)置鏈接讀緩沖區(qū) size
  • SetWriteBuffer 獲取鏈接寫緩沖區(qū) size
  • SetNoDelay 開啟關(guān)閉 no delay 算法
  • ControlFD 支持操作鏈接的原始句柄

有機的組合

前面講到,DMicro 框架萬物皆接口,分層 + 接口的設(shè)計,讓 DMicro 有了靈活的組成高效且符合業(yè)務(wù)實際情況的能力.

接下來我們要講到實現(xiàn)這些能力的基礎(chǔ)。插件系統(tǒng).

插件 Plugin

插件系統(tǒng)給框架帶來了極大的擴展性和靈活性,是整個框架的一個靈魂模塊,有了它,框架就有了無限可能。

什么樣的插件系統(tǒng)才能算是優(yōu)雅呢?我能想到的有以下幾點:

  • 合理且豐富的 hook 位置,能夠覆蓋整個框架的生命周期,貫穿通訊的各個環(huán)節(jié)。
  • 每個 hook 位置的入?yún)⒑统鰠⒍际墙?jīng)過精心設(shè)計。
  • 每個插件都能夠使用多個 hook 位置,每個 hook 位置都能被多個插件使用。
  • 設(shè)計的足夠簡潔,優(yōu)雅。能方便的進行二次開發(fā)定制。

在 drpc 中,鉤子貫穿與整個 Endpoint 的生命周期,是它不可或缺的重要一環(huán)。

 通過這些鉤子 Hook 點,賦予了插件無限可能.

組件

有了插件,就能通過插件的組合,編寫綜合功能的組件,目前框架提供一些內(nèi)置的組件,

  • 服務(wù)端 Rpc Server
  • 客戶端 Rpc Client
  • 服務(wù)注冊 Registry
  • 服務(wù)發(fā)現(xiàn) Selector
  • 事件總線 EventBus
  • 進程管理 Supervisor

即將提供:

  • 鏈路追蹤 Tracing
  • 統(tǒng)計告警 Metrics
  • 限流熔斷 Broker.

限于篇幅的原因,具體組件的實現(xiàn),這里就不深入講解,請關(guān)注后續(xù)的文章.

未來展望

如果把 DMicro 比作人生,現(xiàn)在成長的階段還處在少年時期,只完成了基礎(chǔ)的架構(gòu)設(shè)計和一部分組件的開發(fā).

接下來的方向主要是往易用性和可靠性方向發(fā)展.

易用性:

  • 項目效能工具 dmctl 工具的開發(fā),包括代碼生成,項目結(jié)構(gòu)生成,打包,編譯等等功能.
  • 符合 openapi 定義的文檔組件的開發(fā).
  • 更加完善的文檔和使用示例.

可靠性:

可觀測性

  • 鏈路追蹤
  • 指標(biāo)信息
  • 日志流

生產(chǎn)可用

  • 測試用例的完善
  • 代碼覆蓋率
  • 性能調(diào)優(yōu)

希望 DMicro 能在大家的呵護及鞭策下茁長成長.

開源不易,需要更多小伙伴加入,共創(chuàng) DMicro. 如果你希望使用 DMicro, 趕快引入代碼,搭建你的第一個新項目吧!如果你也想為 DMicro 生態(tài)添磚加瓦,趕快 Fork 代碼,給我們提交 pr 吧!

以上就是Go 微服務(wù)開發(fā)框架DMicro設(shè)計思路詳解的詳細(xì)內(nèi)容,更多關(guān)于Go 微服務(wù)開發(fā)框架DMicro的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Golang使用singleflight解決并發(fā)重復(fù)請求

    Golang使用singleflight解決并發(fā)重復(fù)請求

    高并發(fā)的場景下,經(jīng)常會出現(xiàn)并發(fā)重復(fù)請求資源的情況,singleflight是golang內(nèi)置的一個包,這個包提供了對重復(fù)函數(shù)調(diào)用的抑制功能,所以下面我們就來看看如何使用它解決并發(fā)重復(fù)請求吧
    2023-08-08
  • golang對etcd存取和數(shù)值監(jiān)測的實現(xiàn)

    golang對etcd存取和數(shù)值監(jiān)測的實現(xiàn)

    這篇文章主要介紹了golang對etcd存取和數(shù)值監(jiān)測的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • golang gin 框架 異步同步 goroutine 并發(fā)操作

    golang gin 框架 異步同步 goroutine 并發(fā)操作

    這篇文章主要介紹了golang gin 框架 異步同步 goroutine 并發(fā)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • Go語言使用字符串的幾個技巧分享

    Go語言使用字符串的幾個技巧分享

    這篇文章中小編將給出一些Go語言在處理字符串方面的技巧,對大家學(xué)習(xí)Go語言具有一定的參考借鑒價值,下面一起看看吧。
    2016-09-09
  • go中new和make的區(qū)別小結(jié)

    go中new和make的區(qū)別小結(jié)

    new 只分配內(nèi)存,make 用于初始化 slice、map 和 channel,本文詳細(xì)的介紹了go中new和make的區(qū)別小結(jié),感興趣的可以了解一下
    2023-05-05
  • Golang中可比較的數(shù)據(jù)類型詳解

    Golang中可比較的數(shù)據(jù)類型詳解

    在日常開發(fā)中,比較操作是最常用的基本操作之一,可以用來判斷變量之間是否相等或者對應(yīng)的大小關(guān)系,本文將深入解析 Golang 中可比較的數(shù)據(jù)類型,并結(jié)合代碼示例來說明如何在不同情況下進行比較,需要的朋友可以參考下
    2024-01-01
  • 解決GO編譯時避免引入外部動態(tài)庫的問題

    解決GO編譯時避免引入外部動態(tài)庫的問題

    最近碰到一個問題,有一個流量采集的組件中使用到了github.com/google/gopacket 這個庫,這個庫使用一切正常,但是唯獨有一個缺點,編譯后的二進制文件依賴于libpcap.so的動態(tài)庫,這篇文章主要介紹了GO編譯時避免引入外部動態(tài)庫的解決方法,需要的朋友可以參考下
    2022-10-10
  • Golang中堆排序的實現(xiàn)

    Golang中堆排序的實現(xiàn)

    堆是一棵基于數(shù)組實現(xiàn)的特殊的完全二叉樹,本文主要介紹了Golang中堆排序的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 解決Golang在Web開發(fā)時前端莫名出現(xiàn)的空白換行

    解決Golang在Web開發(fā)時前端莫名出現(xiàn)的空白換行

    最近在使用Go語言開發(fā)Web時,在前端莫名出現(xiàn)了空白換行,找了網(wǎng)上的一些資料終于找到了解決方法,現(xiàn)在分享給大家,有需要的可以參考。
    2016-08-08
  • GoLang內(nèi)存泄漏原因排查詳解

    GoLang內(nèi)存泄漏原因排查詳解

    內(nèi)存溢出是指程序在申請內(nèi)存時,沒有足夠的內(nèi)存空間供其使用,簡單點說就是你要求分配的內(nèi)存超出了系統(tǒng)能給你的,系統(tǒng)不能滿足需求,于是產(chǎn)生溢出出現(xiàn)out of memory異常
    2022-12-12

最新評論