golang nsq消費者時間過長,防止與nsqd服務斷開連接

在使用nsq消費時,發現如果HandleMessage方法執行時間超過2分鐘,在此方法運行完後,就會 拋出 IO error - EOF 錯誤。測試發現,當超過2分鐘時,nsqadmin 後臺顯示的節點未連接。在查看github Issues時,有人提出過,於是做了測試,發現一切正常。(在實際開發中,不建議把慢執行放在消費服務裏,因爲HandleMessage方法不執行完,是不會消費下一個隊列消息的)

func (m *MyHandler) HandleMessage(msg *nsq.Message) (err error) {
	// msg.NSQDAddress的地址是[--broadcast-address所指的ip] --broadcast-address=nsqd
	fmt.Printf("%s recv from %v, msg:%v\n", m.Title, msg.NSQDAddress, string(msg.Body))
	done := make(chan int)
	go func() {
		t := time.Tick(time.Second * 10)
		for {
			select {
			case <-t:
				fmt.Println("touch.")
				msg.Touch()
			case <-done:
				return
			}
		}
	}()
	// 測試sleep500秒
	time.Sleep(time.Second * 500) 
	done <- 1

	/*//msg.DisableAutoResponse()  // 禁用自動提交
	// err := 執行業務邏輯
	if err != nil {
		//msg.Requeue(time.Second * 5) // 重新放入隊列消費
	} else {
		//msg.Finish() // 手動提交消費完成,移出隊列
	}*/
	return
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章