Быстрый маленький, почти функциональный пример, чтобы дать вам идею
var c = make(chan *websocket.Conn, 5) //5 is an arbitrary buffer size
var c2 = make(chan []byte, 5)
func EchoServer(ws *websocket.Conn) {
buff := make([]byte, 256)
c <- ws
for size, e := ws.Read(buff); e == nil; size, e = ws.Read(buff) {
c2 <- buff[0:size]
}
ws.Close()
}
func main() {
go func() {
var somekindofstorage
for {
select {
case newC := <-c:
somekindofstorage.Add(newC)
case msg := <-c2:
for _, v := range somekindofstorage {
if _, e := v.Write(msg); e != nil { //assuming the client disconnected on write errors
somekindofstorage.Remove(v)
}
}
}
}
}()
http.Handle("/echo", websocket.Handler(EchoServer));
http.ListenAndServe(":12345", nil);
}
При этом запускается процедура, которая прослушивает два канала: один для добавления новых соединений и один для отправки сообщений всем активным соединениям. somekindofstorage
может быть картой или вектором.
Edit:
Кроме того, вы можете просто сохранить все соединения в глобальной карте и записать каждое из них с EchoServer
. Но карты не предназначены для одновременного доступа.