go, и вообще на вебсокеты. Если вкратце, то одно веб приложение у меня что-то отправляет в редис, а небольшой код на го слушает редис канал и отправляет сообщения из него в открытые соединения, и всё работает. Но у меня возник вопрос, когда go отключит от себя соединение?
http.HandleFunc("/questionnaire", func(w http.ResponseWriter, r *http.Request) {
upgrader.CheckOrigin = func(r *http.Request) bool { return true }
conn, err := upgrader.Upgrade(w, r, nil)
if err != nil {
log.Printf("Error while upgrade connection %v", err)
return
}
log.Printf("New connection from %v address", conn.RemoteAddr().String())
questionnaireId := r.URL.Query().Get("id")
log.Printf("questionnaireId %v", questionnaireId)
defer conn.Close()
pubsub := rdb.Subscribe(ctx, fmt.Sprintf("questionnaire:%v:report:new", questionnaireId))
for {
log.Printf("Connection %v address", conn.RemoteAddr().String())
msg, err := pubsub.ReceiveMessage(ctx)
if err != nil {
fmt.Println("Error while get message from redis channel subscribe")
return
}
var report Report
err = json.Unmarshal([]byte(msg.Payload), &report)
if err != nil {
fmt.Println("Error while serialize json from channel")
return
}
if err = conn.WriteMessage(websocket.TextMessage, []byte(msg.Payload)); err != nil {
return
}
}
})
Фото отправлять нельзя, надеюсь так что-то будет видно. Когда сработает defer conn.Close() ? ведь там дальше всё крутится в цикле
Или когда соединения закрывается на фронте, то всё, этот цикл останавливается?
И ещё интересно можно ли как-то валидировать запрос на соединение?
Обсуждают сегодня