[コード記事]独自のgolangフレームワークを一から段階的に構築します(7)

このフレームワークの目的は一般的なフレームワークになることですが、それが大きくて包括的で、将来他のプロジェクトの基本テンプレートとして使用できることを願っています。この記事では、キュー関数を追加します。

nsq

キューにはさまざまな種類がありますが、私はnsqを選択します。nsqを使用して、次の概念を理解する必要があります。

  1. nsqd:キューの維持、メッセージのキューイングと配信の受け入れを担当するコンポーネント。
  2. nsqlookupd:nsqクラスターのコンポーネントを管理します。
  3. nsqadmin:nsqのWeb管理コンポーネント。
  4. トピック:メッセージのコレクション。メッセージを生成するには、メッセージが属するトピックを指定する必要があります。
  5. チャネル:キューメッセージのコピー。nsqコンシューマは、nsqdまたはnsqlookupdを使用してチャネルを確立し、チャネルでメッセージをリッスンして消費を達成します。

nsqのいくつかの基本的な概念を理解した後、最初にnsq環境をセットアップしますが、ここでは今でもdocker-composeを使用しています。

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 /、対応するトピックと生成も確認できます。
nsqadmin.png

次に、コード、古いルールを変更し、最初に構成を変更します。

"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)
	}
}

完全なコードについては、https//github.com/TomatoMr/awesomeframeworkを参照してください


私の公開番号であるonepunchgoに注目してください。メッセージを残してください。

画像

元の記事を20件公開 Likes0 訪問数764

おすすめ

転載: blog.csdn.net/qq_31362439/article/details/104339693