Go實(shí)現(xiàn)共享庫(kù)的方法
Don't Repeat Yourself 不要重復(fù)自己,這是軟件開發(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-11Go語(yǔ)言實(shí)現(xiàn)管理多個(gè)數(shù)據(jù)庫(kù)連接
在軟件開發(fā)過(guò)程中,使用?MySQL、PostgreSQL?或其他數(shù)據(jù)庫(kù)是很常見的,由于配置和要求不同,管理這些連接可能具有挑戰(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