このフレームワークの目的は一般的なフレームワークになることですが、それが大きくて包括的で、将来他のプロジェクトの基本テンプレートとして使用できることを願っています。この記事では、キュー関数を追加します。
nsq
キューにはさまざまな種類がありますが、私はnsqを選択します。nsqを使用して、次の概念を理解する必要があります。
- nsqd:キューの維持、メッセージのキューイングと配信の受け入れを担当するコンポーネント。
- nsqlookupd:nsqクラスターのコンポーネントを管理します。
- nsqadmin:nsqのWeb管理コンポーネント。
- トピック:メッセージのコレクション。メッセージを生成するには、メッセージが属するトピックを指定する必要があります。
- チャネル:キューメッセージのコピー。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 /、対応するトピックと生成も確認できます。
次に、コード、古いルールを変更し、最初に構成を変更します。
"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に注目してください。メッセージを残してください。