您好,登錄后才能下訂單哦!
本篇內容主要講解“Go如何實現共享庫”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Go如何實現共享庫”吧!
使用共享庫可以協助我們管理代碼重用的問題,但是需要考慮共享庫依賴和變更控制的問題。
如果有幾個服務都使用了一個共享庫:
共享庫發生變更,每個服務都需要使用新版本共享庫。舊版本的共享庫如果被棄用就會導致服務不可使用,所以在這種情況下,每次發生變更時就需要重新測試和重新部署服務。
服務發生變更就需要更改共享庫,這樣共享庫就失去通用性的特征。說明共享庫包含服務相關的服務的業務邏輯。但這樣是錯誤的,共享庫不應該與服務有任何關聯的代碼塊
如果有幾個服務都有使用多個共享庫:
不同的服務使用不同的庫,依賴多個庫。共享庫越多,依賴就越多,就會導致依賴管理變得困難。
以Go 操作 RabbitMQ 創建一個共享庫為例子,需要初始化 MQ實例,創建連接,重連機制、關閉,消費者通道,創建隊列,隊列綁定交換機等等功能。
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) }
創建完之后需要再創建一個合適的標簽 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 } }
如果你想測試你的庫而不發布它,你可以使用 replace 指令。 將依賴庫的地址指向本地的文件的地址。
replace github.com/nanlv/rabbitmq-sdk v1.0.0 => 項目在本地的地址
到此,相信大家對“Go如何實現共享庫”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。