基于Golang协程实现流量统计系统

凌云社区_Java_B · · 5795 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

第1章 课程介绍

欢迎大家学习Go语言,本课程基于Go协程特性,实现企业级流量统计系统。关于Go语言,是一门朝气蓬勃富有战斗力的语言,它近些年的发展势头完全不亚于2012年前后的PHP语言,越来越多的Go语言爱好者、工程师。协程是Go最吸引眼球的特性,它将带你走进函数式编程的新世界。...

1-1 课程概览

第2章 并发模型

并发模型对于科班出生的同学并不陌生,在近些年的高级语言中,大量应用线程的并发能力做高并发应用,本章节将从并发模型开始,带你进入更轻量更高并发度的并发世界

2-1 并发编程启蒙

2-2 并发编程--协程

2-3 Golang协程基本示例

第3章 Go的协程

Go语言天生自带协程:协程即Goroutine,但只学习Goroutine可远远不足以满足项目开发需要,本章介绍Go协程在做真实项目研发时所需要涉及的周边函数能力。以Sample代码为入手,让Go语言零基础的同学不掉队。

3-1 Golang协程特性实践

3-2 golang select多队列选择器

3-3 selete等待机制

第4章 示例环境搭建

流量统计系统应用于成型互联网公司线上流量统计,本章节带领大家搭建一套含有一万多条数据的视频网站,整站嵌入用户信息上报JS,实时上报用户浏览情况,用于服务端统计分析。

4-1 快速构建一个示例网站(上)

4-2 快速构建一个示例网站(下)

4-3 上报用户信息数据到打点服务器

4-4 Nginx打点服务器的搭建与配置

第5章 Go批量生成日志

本章节通过一步步编写Go语言脚本,带大家实现一个可以自定义数量级的线上日志生成工具,用于模拟大量用户访问视频网站所产生的打点请求,生成数万行日志,用于后续统计分析系统消费。

5-1 创建解析样本(一)

5-2 创建解析样本(二)

5-3 创建解析样本(三)

第6章 统计系统框架构成

打点数据统计系统模块的骨架设计先行,将骨干Goroutine、Channel声明在先,一套清晰易懂的框架结构便于开发过程中专注于实现功能,在实际开发前就能摸清程序脉络,少走许多弯路。

6-1 统计分析模块的框架实现(上)

6-2 统计分析模块的框架实现(下)

第7章 统计系统之日志消费

逐行批量的消费线上打点日志,实现四大Goroutine环节第一步,并且实现日志顺序进入带解析通道。对于线上流量凌晨期间的冷时间段,进行一定逻辑的等待循环处理。

7-1 统计分析模块逐行消费日志

第8章 统计系统之批量解析

创建一组用于批量解析日志的Goroutine,是四大环节中并发度最高的环节,可以并行开展,相互之间不受牵制,分别扣取打点日志中关键信息,并构成自定义结构体,对上报信息翻译后放入待统计通道,给未来扩展能力提供了空间。...

8-1 统计分析模块日志解析

第9章 统计系统之统计逻辑

最贴近业务需求的系统子模块,其中采用HyperLogLog能力实现UV天级去重,定义了用于存储数据所需的结构体后,对过往数据进行架构封装,投递至待存储通道,待存储器消费。

9-1 统计分析模块PVUV统计(上)

9-2 统计分析模块PVUV统计(下)

第10章 统计系统之存储器

无业务状态的通用存储Goroutine,将上游派发来的存储诉求逐个落实到存储系统中,并能扩展数据查询所需的时间维度数据,该环节对于存储知识要求较高,需要在不同的存储系统中选好最佳的抉择。

10-1 数据存储(上)

10-2 数据存储(下)

第11章 数据可视化

对于已落实到存储系统中的线上流量数据,本章节借助专业级的Dashboard脚手架Ant Design Pro,呈现美观的线上流量数据结果。彻底打通了用户侧系统的线上流量情况,将结果呈现在企业管理者、决策者的眼前。

11-1 基于Ant Design的数据可视化

第12章 企业级解决方案及课程总结

基于前面所涉及的内容,打通知识点,并且拆解企业级实现时,每个环节应当关注的点与系统方案的核心挑战剖析,抛砖引玉为学员提供更大的想象空间与成长空间

12-1 企业级解决方案的关注点

12-2 课程知识点回顾

下载地址:百度网盘下载


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:凌云社区_Java_B

查看原文:基于Golang协程实现流量统计系统

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

5795 次点击  
加入收藏 微博
下一篇:golang文件操作
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传