Golang心跳机制实现示例

前言:

      最近在做一款产品,服务端需要监测客户端状态(在线/离线)。服务端报表展示客户端的上下线次数和运行时长等信息。

通用的处理方式:

  1. 客户端发送心跳请求+重试机制。重试X次失败则定义为离线

  2. 服务端响应心跳请求+超时机制。超时X秒未收到心跳请求则定义为下线

//服务端​
//全局变量
var ids = make(map[string]chan byte)
​
func ResponseHeartBeat(id string) {
    if _, ok := ids[id]; ok {
        //保活心跳请求
        ids[id] <- 0
    } else {
        //上线触发器
        ids[id] = make(chan byte)
        go HeartBeat(ids, id, 10)
  }
}
​
/**
 *@brief: 心跳事件触发器
 *@param: ids 全局注册表
 *@param: id
 *@param: 超时时间
 */
func HeartBeat(ids map[string]chan byte, id string, n int64) {
  online := true
    for online {
    select {
        case  <- ids[id]:
          //保活触发器
        case <- time.After(time.Duration(n) * time.Second):
          //下线触发器
          online = false
          delete(ids, id)
          //下线触发通知系列功能操作,可采用观察者模式
    }
  }
}

 

你可能感兴趣的:(golang)