Skip to content

akilichen/go-push

 
 

Repository files navigation

go-push

golang实现的、可扩展的通用消息推送原型。

安装

项目采用Godep工具管理依赖,下载源码后可以直接编译,无需手动安装依赖。

  • 导出GOPATH环境变量

  • 下载go-push

go get github.com/owenliang/go-push
  • 编译gateway服务
cd $GOPATH/src/github.com/owenliang/go-push/gateway/cli && go build
  • 编译logic服务
cd $GOPATH/src/github.com/owenliang/go-push/logic/cli && go build

架构

  • gateway: 长连接网关
    • 海量长连接按BUCKET打散, 减小推送遍历的锁粒度
    • 按广播/房间粒度的消息前置合并, 减少编码CPU损耗, 减少系统网络调用, 巨幅提升吞吐
  • logic: 逻辑服务器
    • 本身无状态, 负责将推送消息分发到所有gateway节点
    • 对调用方暴露HTTP/1接口, 方便业务对接
    • 采用HTTP/2长连接RPC向gateway集群分发消息

潜在问题

  • 推送主要瓶颈是gateway层而不是内部通讯, 所以gateway和logic之间仍旧采用了小包通讯(对网卡有PPS压力), 同时logic为业务提供了批量推送接口来缓解特殊需求.

压测

环境

  • 16 vcore
  • client, logic, gateway deployed together

带宽

bandwidth

CPU占用

cpu usage

logic的推送API

  • 全员广播
curl http://localhost:7799/push/all -d 'items=[{"msg": "hi"},{"msg": "bye"}]'
  • 房间广播
curl http://localhost:7799/push/room -d 'room=default&items=[{"msg": "hi"},{"msg": "bye"}]'

gateway的websocekt协议

  • PING(客户端->服务端)
{"type": "PING", "data": {}}
  • PONG(服务端->客户端)
{"type": "PONG", "data": {}}
  • JOIN(客户端->服务端)
{"type": "JOIN", "data": {"room": "fengtimo"}}
  • LEAVE(客户端->服务端)
{"type": "LEAVE", "data": {"room": "fengtimo"}}
  • PUSH(服务端->客户端)
{"type": "PUSH", "data": {"items": [{"name": "go-push"}, {"age": "1"}]}}

golang微信群(加我进群)

wechat

About

用GO做推送

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 93.7%
  • HTML 6.3%