Go實現(xiàn)共享庫的方法
Don't Repeat Yourself 不要重復自己,這是軟件開發(fā)的一個基本原則,目的就是減少重復。但是在系統(tǒng)中不同的部分,可能會有不同的業(yè)務邏輯,若使用相同的功能來解決不同上下文中的問題,那應該使用公共方法來防止代碼重復嗎?
共享庫
使用共享庫可以協(xié)助我們管理代碼重用的問題,但是需要考慮共享庫依賴和變更控制的問題。
如果有幾個服務都使用了一個共享庫:
- 共享庫發(fā)生變更,每個服務都需要使用新版本共享庫。舊版本的共享庫如果被棄用就會導致服務不可使用,所以在這種情況下,每次發(fā)生變更時就需要重新測試和重新部署服務。
- 服務發(fā)生變更就需要更改共享庫,這樣共享庫就失去通用性的特征。說明共享庫包含服務相關(guān)的服務的業(yè)務邏輯。但這樣是錯誤的,共享庫不應該與服務有任何關(guān)聯(lián)的代碼塊
如果有幾個服務都有使用多個共享庫:
不同的服務使用不同的庫,依賴多個庫。共享庫越多,依賴就越多,就會導致依賴管理變得困難。
創(chuàng)建庫
以Go 操作 RabbitMQ 創(chuàng)建一個共享庫為例子,需要初始化 MQ實例,創(chuàng)建連接,重連機制、關(guān)閉,消費者通道,創(chuàng)建隊列,隊列綁定交換機等等功能。
type RabbitMQ struct {
connection *amqp.Connection
channel *amqp.Channel
connURL string
errCh <-chan *amqp.Error
messageChan <-chan amqp.Delivery
retryAttempt int
}
// 初始化 MQ 實例
func NewRabbitMQ(options RabbitMQOptions) (*RabbitMQ, error) {
rabbitMQ := &RabbitMQ{
connURL: options.URL,
retryAttempt: options.RetryAttempt,
}
if err := rabbitMQ.connect(); err != nil {
return nil, err
}
return rabbitMQ, nil
}
func (rmq *RabbitMQ) connect() error {}
func (rmq *RabbitMQ) reconnect() {}
func (rmq *RabbitMQ) Close() {}
func (rmq *RabbitMQ) ConsumeMessageChannel() (jsonBytes []byte, err error) {
func (rmq *RabbitMQ) CreateQueue(name string, durable bool, autoDelete bool, exclusive bool, noWait bool, args map[string]interface{}) (amqp.Queue, error) }
創(chuàng)建完之后需要再創(chuàng)建一個合適的標簽 tag 或版本號來共享該代碼。使用過 github 都可以在 release 中看到版本號和 tag 。
使用庫
首先,我們需要使用 go get 安裝這個共享庫。 之后,我們必須在我們的項目中導入我們的庫,如下所示。
package main
import (
"fmt"
rabbitmq_sdk "github.com/nanlv/rabbitmq-sdk"
)
func main() {
fmt.Println("connect MQ")
options := rabbitmq_sdk.RabbitMQOptions{
URL: "amqp://root:root@localhost:5672/",
RetryAttempt: 5,
}
rabbitMQ, err := rabbitmq_sdk.NewRabbitMQ(options)
if err != nil {
return
}
queue, err := rabbitMQ.CreateQueue("queue1", true, true, false, false, nil)
if err != nil {
fmt.Println(err.Error())
return
}
}
如果你想測試你的庫而不發(fā)布它,你可以使用 replace 指令。 將依賴庫的地址指向本地的文件的地址。
replace github.com/nanlv/rabbitmq-sdk v1.0.0 => 項目在本地的地址
總結(jié)
若兩個部分使用相同的庫可能會增加依賴和耦合。因為它們具有不同的業(yè)務邏輯,在業(yè)務獨立演進時,就會增加耦合和維護成本。耦合是衡量兩個組件間了解和互相依賴程度的指標。耦合度越高,依賴性越高。
共享庫可以解決代碼重復的問題。但需要做好版本管理和變更控制。使用 Go 可以創(chuàng)建一個共享庫然后上傳到 github。就可以將其作為一個共享庫使用。
到此這篇關(guān)于Go實現(xiàn)共享庫的方法的文章就介紹到這了,更多相關(guān)Go 共享庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Go語言Swagger實現(xiàn)為項目生成 API 文檔
Swagger 是一個基于 OpenAPI 規(guī)范設(shè)計的工具,用于為 RESTful API 生成交互式文檔,下面小編就來介紹一下如何在 Go 項目中集成 Swagger,特別是結(jié)合 Gin 框架生成 API 文檔2025-03-03
使用Go基于WebSocket構(gòu)建千萬級視頻直播彈幕系統(tǒng)的代碼詳解
這篇文章主要介紹了使用Go基于WebSocket構(gòu)建千萬級視頻直播彈幕系統(tǒng),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07
golang并發(fā)編程中Goroutine 協(xié)程的實現(xiàn)
Go語言中的協(xié)程是一種輕量級線程,通過在函數(shù)前加go關(guān)鍵字來并發(fā)執(zhí)行,具有動態(tài)棧、快速啟動和低內(nèi)存使用等特點,本文就來詳細的介紹一下,感興趣的可以了解一下2024-10-10

