1-5 Go 语言构建高并发分布式系统实践.pdf
文本预览下载声明
go语⾔并发编程实践
以360 消息推送系统为例
周洋
部⻔: 360⼿机助⼿
Weibo: @johntech-o
Date: 2015.04.25
⺫录
go语⾔在基础服务开发领域的优势?
我遭遇了哪些挑战?
如何应对的?
具有go特⾊的运维
在⾼并发,通信交互复杂,重业务逻辑的分布式系统中,
Go语⾔优势体现在:开发体验好、⼀定量级下服务稳定、性能满⾜
需要
以360 消息推送系统为例
⼀定量级下服务稳定:
50+内部产品,万款开发平台app
实时⻓连接数亿量级,⽇独数⼗亿量级
1 ,
分钟内亿量级⼲播 ⽇下发峰值百亿量级
400 9 10 IDC
台物理机, 个独⽴集群,国内外近 个
go service 3000
运维管理的 语⾔编写的常驻 服务实例接近 个。
业务场景多样:
⽀持聊天场景业务,稳定⽀持多款聊天业务app
app
单通道多 复⽤
上⾏通道,回调⽀持
对智能硬件产品,提供定制化消息推送与转发服务
性能满⾜需要:
160w 24 E5-2630 @ 2.30GHz 64G
线上单机最⾼ ⻓连接 ( 核 内存)
qps在2~5w (取决于协议版本,业务逻辑,接⼊端⺴络状况)
300w , , ,
测试环境,可以通过 ⻓连接压测(⺴络连接稳定⽆带宽限制实际可以更⾼
, cpu
决定于⼲播时候业务内存开销的 消耗带来的⼼跳或者业务延时能否接受)
⾼并发、通信交互复杂 Iframe Flash
Android IOS Windows Linux for ever Web
接入客户端
Dispatcher Room Proxy
Service Service
显示全部