123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- package server
- import (
- "sync"
- "sikey.com/websocket/config"
- "sikey.com/websocket/utils/zlog"
- "github.com/redis/go-redis/v9"
- )
- type HubConfig struct {
- ServerId string // serverId 服务器ID
- Rdb redis.UniversalClient
- }
- type Hub struct {
- serverId string // serverId 服务器ID
- rdb redis.UniversalClient
- clients map[string]*Client
- mutex sync.RWMutex
- Connect chan *Client
- Disconnect chan *Client
- Message chan *Message
- exchange *Exchange
- }
- func NewHub(cfg HubConfig) *Hub {
- hub := &Hub{
- serverId: cfg.ServerId,
- clients: make(map[string]*Client),
- mutex: sync.RWMutex{},
- Connect: make(chan *Client, config.Websocket.ConnectSize),
- Disconnect: make(chan *Client, config.Websocket.ConnectSize),
- Message: make(chan *Message, config.Websocket.MessageSize),
- }
- hub.exchange = NewExchange(cfg.ServerId, cfg.Rdb)
- go hub.run()
- return hub
- }
- func (h *Hub) run() {
- for {
- select {
- case client := <-h.Connect:
- h.mutex.Lock()
- h.clients[client.UserId] = client
- // h.exchange.OnPublishConnect(client)
- h.mutex.Unlock()
- case client := <-h.Disconnect:
- h.mutex.Lock()
- close(client.Send)
- delete(h.clients, client.UserId)
- // h.exchange.OnPublishDisconnect(client)
- h.mutex.Unlock()
- case message := <-h.Message:
- h.mutex.RLock()
- if client, ok := h.clients[message.Receiver]; ok {
- if client.isRemotely {
- h.exchange.OnPublishMessage(client, message)
- } else {
- zlog.Info("message: ", message)
- client.Send <- message
- }
- }
- h.mutex.RUnlock()
- case conn := <-h.exchange.Connect:
- h.mutex.Lock()
- h.clients[conn.UserId] = &Client{
- isRemotely: true,
- hub: h,
- Send: make(chan *Message),
- }
- h.mutex.Unlock()
- case conn := <-h.exchange.Disconnect:
- h.mutex.Lock()
- if client, ok := h.clients[conn.UserId]; ok {
- close(client.Send)
- delete(h.clients, client.UserId)
- }
- h.mutex.Unlock()
- case message := <-h.exchange.Message:
- h.mutex.RLock()
- if client, ok := h.clients[message.Receiver]; ok {
- client.Send <- message
- }
- h.mutex.RUnlock()
- }
- }
- }
- func (h *Hub) GetClients() map[string]*Client {
- return h.clients
- }
|