溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Go如何實現(xiàn)共享庫

發(fā)布時間:2023-02-24 09:44:07 來源:億速云 閱讀:112 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容主要講解“Go如何實現(xiàn)共享庫”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“Go如何實現(xiàn)共享庫”吧!

共享庫

使用共享庫可以協(xié)助我們管理代碼重用的問題,但是需要考慮共享庫依賴和變更控制的問題。

如果有幾個服務(wù)都使用了一個共享庫:

  • 共享庫發(fā)生變更,每個服務(wù)都需要使用新版本共享庫。舊版本的共享庫如果被棄用就會導(dǎo)致服務(wù)不可使用,所以在這種情況下,每次發(fā)生變更時就需要重新測試和重新部署服務(wù)。

  • 服務(wù)發(fā)生變更就需要更改共享庫,這樣共享庫就失去通用性的特征。說明共享庫包含服務(wù)相關(guān)的服務(wù)的業(yè)務(wù)邏輯。但這樣是錯誤的,共享庫不應(yīng)該與服務(wù)有任何關(guān)聯(lián)的代碼塊

如果有幾個服務(wù)都有使用多個共享庫:

不同的服務(wù)使用不同的庫,依賴多個庫。共享庫越多,依賴就越多,就會導(dǎo)致依賴管理變得困難。

創(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 安裝這個共享庫。 之后,我們必須在我們的項目中導(dǎo)入我們的庫,如下所示。

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 => 項目在本地的地址

到此,相信大家對“Go如何實現(xiàn)共享庫”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

go
AI