Go實(shí)現(xiàn)共享庫(kù)的方法
Don't Repeat Yourself 不要重復(fù)自己,這是軟件開(kāi)發(fā)的一個(gè)基本原則,目的就是減少重復(fù)。但是在系統(tǒng)中不同的部分,可能會(huì)有不同的業(yè)務(wù)邏輯,若使用相同的功能來(lái)解決不同上下文中的問(wèn)題,那應(yīng)該使用公共方法來(lái)防止代碼重復(fù)嗎?
共享庫(kù)
使用共享庫(kù)可以協(xié)助我們管理代碼重用的問(wèn)題,但是需要考慮共享庫(kù)依賴和變更控制的問(wèn)題。
如果有幾個(gè)服務(wù)都使用了一個(gè)共享庫(kù):
- 共享庫(kù)發(fā)生變更,每個(gè)服務(wù)都需要使用新版本共享庫(kù)。舊版本的共享庫(kù)如果被棄用就會(huì)導(dǎo)致服務(wù)不可使用,所以在這種情況下,每次發(fā)生變更時(shí)就需要重新測(cè)試和重新部署服務(wù)。
- 服務(wù)發(fā)生變更就需要更改共享庫(kù),這樣共享庫(kù)就失去通用性的特征。說(shuō)明共享庫(kù)包含服務(wù)相關(guān)的服務(wù)的業(yè)務(wù)邏輯。但這樣是錯(cuò)誤的,共享庫(kù)不應(yīng)該與服務(wù)有任何關(guān)聯(lián)的代碼塊
如果有幾個(gè)服務(wù)都有使用多個(gè)共享庫(kù):
不同的服務(wù)使用不同的庫(kù),依賴多個(gè)庫(kù)。共享庫(kù)越多,依賴就越多,就會(huì)導(dǎo)致依賴管理變得困難。
創(chuàng)建庫(kù)
以Go 操作 RabbitMQ 創(chuàng)建一個(gè)共享庫(kù)為例子,需要初始化 MQ實(shí)例,創(chuàng)建連接,重連機(jī)制、關(guān)閉,消費(fèi)者通道,創(chuàng)建隊(duì)列,隊(duì)列綁定交換機(jī)等等功能。
type RabbitMQ struct {
connection *amqp.Connection
channel *amqp.Channel
connURL string
errCh <-chan *amqp.Error
messageChan <-chan amqp.Delivery
retryAttempt int
}
// 初始化 MQ 實(shí)例
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)建一個(gè)合適的標(biāo)簽 tag 或版本號(hào)來(lái)共享該代碼。使用過(guò) github 都可以在 release 中看到版本號(hào)和 tag 。
使用庫(kù)
首先,我們需要使用 go get 安裝這個(gè)共享庫(kù)。 之后,我們必須在我們的項(xiàng)目中導(dǎo)入我們的庫(kù),如下所示。
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
}
}
如果你想測(cè)試你的庫(kù)而不發(fā)布它,你可以使用 replace 指令。 將依賴庫(kù)的地址指向本地的文件的地址。
replace github.com/nanlv/rabbitmq-sdk v1.0.0 => 項(xiàng)目在本地的地址
總結(jié)
若兩個(gè)部分使用相同的庫(kù)可能會(huì)增加依賴和耦合。因?yàn)樗鼈兙哂胁煌臉I(yè)務(wù)邏輯,在業(yè)務(wù)獨(dú)立演進(jìn)時(shí),就會(huì)增加耦合和維護(hù)成本。耦合是衡量?jī)蓚€(gè)組件間了解和互相依賴程度的指標(biāo)。耦合度越高,依賴性越高。
共享庫(kù)可以解決代碼重復(fù)的問(wèn)題。但需要做好版本管理和變更控制。使用 Go 可以創(chuàng)建一個(gè)共享庫(kù)然后上傳到 github。就可以將其作為一個(gè)共享庫(kù)使用。
到此這篇關(guān)于Go實(shí)現(xiàn)共享庫(kù)的方法的文章就介紹到這了,更多相關(guān)Go 共享庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Golang中的[]byte與16進(jìn)制(String)之間的轉(zhuǎn)換方式
這篇文章主要介紹了Golang中的[]byte與16進(jìn)制(String)之間的轉(zhuǎn)換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11
Go語(yǔ)言實(shí)現(xiàn)管理多個(gè)數(shù)據(jù)庫(kù)連接
在軟件開(kāi)發(fā)過(guò)程中,使用?MySQL、PostgreSQL?或其他數(shù)據(jù)庫(kù)是很常見(jiàn)的,由于配置和要求不同,管理這些連接可能具有挑戰(zhàn)性,下面就來(lái)和大家聊聊如何在Go中管理多個(gè)數(shù)據(jù)庫(kù)連接吧2023-10-10
探索分析Go?HTTP?GET請(qǐng)求發(fā)送body
這篇文章主要為大家介紹了探索分析Go?HTTP?GET請(qǐng)求發(fā)送body,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11

