亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

怎么搭建golang框架

發布時間:2020-05-29 19:03:26 來源:億速云 閱讀:272 作者:鴿子 欄目:編程語言

這個框架的目標是作為一個通用的框架,我希望它大而全,在日后可以直接作為我其他項目的基礎模板,所以我還想繼續給他添加一些功能,就當寫一些demo進去吧。這篇文章,我將會添加一個隊列的功能。

nsq

隊列有很多種,我選擇nsq。使用nsq需要知道以下幾個概念:

  1. nsqd:負責維護隊列的組件,接受消息排隊和投遞;
  2. nsqlookupd:管理nsq集群的組件;
  3. nsqadmin:nsq的web管理組件;
  4. topic:消息的集合。產生消息,需要指定該消息屬于哪個topic的;
  5. channel:隊列消息的副本。nsq消費者與nsqd或者nsqlookupd建立一個channel,并監聽channel中的消息,從而實現消費。

了解了一些nsq的基礎概念之后,我們先把nsq環境搭建起來,這里我們還是用docker-compose好了,以下是nsq的docker-compose.yaml。

version: '3'
services:
  nsqlookupd:
    image: nsqio/nsq
    command: /nsqlookupd
    networks:
      - nsq-network
    hostname: nsqlookupd
    ports:
      - "4161:4161"
      - "4160:4160"
  nsqd:
    image: nsqio/nsq
    command: /nsqd --lookupd-tcp-address=nsqlookupd:4160 --broadcast-address=nsqd
    depends_on:
      - nsqlookupd
    hostname: nsqd
    networks:
      - nsq-network
    ports:
      - "4151:4151"
      - "4150:4150"
  nsqadmin:
    image: nsqio/nsq
    command: /nsqadmin --lookupd-http-address=nsqlookupd:4161
    depends_on:
      - nsqlookupd
    hostname: nsqadmin
    ports:
      - "4171:4171"
    networks:
      - nsq-network

networks:
  nsq-network:
    driver: bridge

啟動了nsq服務之后,我們簡單地驗證一下,發布一條消息到nsq中:

curl -d 'hello awesome' 'http://127.0.0.1:4151/pub?topic=awesome'

瀏覽器訪問:http://localhost:4171/,我們也可以看到有相應的topic和產生

接著我們修改一下代碼,老規矩,先改配置:

"nsq_config":
  "topic": "awesome"
  "channel": "ch"
  "nsqlookupd_addr": "127.0.0.1:4161"
type NsqConfig struct {
    Topic          string `yaml:"topic"`
    Channel        string `yaml:"channel"`
    NsqLookupdAddr string `yaml:"nsqlookupd_addr"`
}

然后在mq.go中添加一個啟動mq消費者的函數:

func StartMqServer() {
    conf := nsq.NewConfig()
    q, _ := nsq.NewConsumer(config.GetConfig().NsqConfig.Topic, config.GetConfig().NsqConfig.Channel, conf)
    q.AddHandler(nsq.HandlerFunc(func(message *nsq.Message) error {
        //do something when you receive a message
        logger.GetLogger().Info("receive", zap.String(config.GetConfig().NsqConfig.Topic, string(message.Body)))
        return nil
    }))
    err := q.ConnectToNSQLookupd(config.GetConfig().NsqConfig.NsqLookupdAddr)
    if err != nil {
        logger.GetLogger().Error("connect to nsqlookupd failed.", zap.Error(err))
        os.Exit(-1)
    }
}

同樣在入口文件,啟動它:

go mq.StartMqServer()

最后,我們寫個生產者,生成一條消息,測試一下:

func TestProducer(t *testing.T)  {
    config := nsq.NewConfig()
    p, err := nsq.NewProducer("127.0.0.1:4150", config)

    if err != nil {
        log.Panic(err)
    }

    err = p.Publish("awesome", []byte("hello awesome"))
    if err != nil {
        log.Panic(err)
    }
}

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

年辖:市辖区| 苗栗县| 宁陕县| 邯郸县| 蕉岭县| 醴陵市| 师宗县| 文成县| 襄汾县| 白银市| 昌宁县| 吉木萨尔县| 什邡市| 洛川县| 大关县| 霍林郭勒市| 滦平县| 凤城市| 永川市| 育儿| 盘山县| 洛隆县| 凉城县| 桦南县| 景洪市| 加查县| 甘洛县| 布尔津县| 昆山市| 大足县| 茶陵县| 英吉沙县| 公主岭市| 德令哈市| 连云港市| 天台县| 蒲城县| 宝清县| 洛浦县| 新巴尔虎左旗| 察雅县|