埋点治理:如何把App埋点做到极致?

栏目: IT技术 · 发布时间: 4年前

内容简介:背景

导语

本文 基于实际场景业务 需求 ,通过切面化、平台化、动态化探讨埋点治理方案,把App埋点做到极致,具有一定的实践意义,希望对大家有所帮助和启发。

背景

埋点日志的统计,数据的分析,直接影响产品方向和运营决策。对于黄页类产品,由于本身种类繁多,埋点体量大,在实际的开发和统计过程中遇到了很多问题,本文所探讨的埋点治理方案基于实际场景的需求所提出的,具有一定的实践意义,以下是例举的实际场景下的需求与对应解决方案,如下图所示:

埋点治理:如何把App埋点做到极致?

需求问题,解决方案,埋点系统

现有埋点方案比较

1. 传统代码埋点

实现方案:Coding阶段手动埋点。

代表解决方案:友盟、百度统计。

优点:灵活、准确,可以定制化。

缺点:业务埋点量非常大,开发成本高,不易维护,如果要修改、新增埋点,需要重新发版。

2. 动态埋点

实现方案:利用AccessibilityDelegate对每个view实例设置代理,监听控件点击事件。

代表方案:Github上开源的Mixpanel

优点:无需手动埋点,通过可视化圈选,动态下发配置监听指定控件。

缺点:不支持数据可回溯,采集不到Fragment页面数据,只支持API 14及以上,同时该监听方式对app性能影响严重,每个控件都需要动态绑定,在界面变更时,需要重新刷新ViewTree,效率低下。

3. 全埋点方案

实现方案:利用Gradle插件,在编译阶段在代码中插入埋点代码,进行数据采集。

代表方案:GrowingIO、美团的替换UI控件方案,WMDA

优点:开发效率高,无需手动埋点,编译时插入代码,性能高,支持数据可回溯。

缺点:埋点灵活性低。

现有的埋点方案各有利弊,没有一种方案可以完美的解决所有埋点问题,本方案中采用了手动埋点,WMDA全埋点方案,切面化动态埋点相结合的埋点方案,针对不同场景和埋点需求使用不同的埋点策略,尽可能的把埋点问题做到极致。

系统建立

1. 整体架构

埋点治理:如何把App埋点做到极致?

埋点系统整体架构图

埋点系统主要做了三个事情

1. 相似埋点的切面化;

2. 特定埋点的动态化;

3. 管理验证的平台化;

接下来将会详细说明。

2. 切面化 降低耦合 提高效率

埋点治理:如何把App埋点做到极致?

切面化部分

主要指App内部的针对埋点Aop和拦截器方案:

a) 拦截器

如页面级别的通用参数,比如在所有列表页的埋点里面加入,通过页面生命周期控制注册销毁拦截器,对该页面所有埋点进行统一的处理下图左侧所示

b) Aop

方法级别的统一埋点,比如详情页所有Item的展示,通过AspectJ对详情页Item的onCreateView方法进行,切割并注入埋点代码,使所有详情页展示埋点统一。  

埋点治理:如何把App埋点做到极致?

拦截器,Aop

3 、动态化 避免发版  

埋点治理:如何把App埋点做到极致?

动态化部分

具体内容:

a)LogParams 和 Passvalue

埋点治理:如何把App埋点做到极致?

LogParam,PassValue

logParams是服务端从请求返回的专为埋点的参数 比如详情页包括 外层logParam。

item级别logParam等等,逐层嵌套覆盖,生成最终实际的埋点参数,实现埋点参数的动态化。PassValue主要使用透传,跟随跳转协议,用于服务端日志,电话连接请求与参数,实现请求参数的动态化。

b)WMDA

为了解决产品临时的统计需求,引入了WMDA(WMDA是公司针对App的一套全埋点实现,针对解决临时埋点需求,提供圈选回溯的功能),主要处理页面级别的展示量和固定View的点击量。

c)动态埋点

埋点治理:如何把App埋点做到极致?

动态埋点框架

整体说整套动态埋点方案是基于切面插桩和反射机制的。以Android为例,

开发时在对应需要埋点或可能需要统计的地方添加注解,编译期通AspectJ插入埋点代码,并通过上传插件上传可埋点方法文件,何Mapping文件,可埋点方法文件如下图所示是由一个个Apath组成。

埋点治理:如何把App埋点做到极致?

Apath

每个Apath由注释,类名,方法名,参数名组成,被上传到服务端,在通过配置需要的埋点以及参数,已如图所示的协议在下发到客户端map存储。Key就是方法名,值就是整个协议体。

埋点治理:如何把App埋点做到极致?

配置上传下发示意图

运行时,当方法被调用时,检测内存中Key有没有该方法如果有则通过反射获取对应参数合并服务端参数生成日志上传。

埋点治理:如何把App埋点做到极致?

运行时逻辑

动态埋点sdk 接入和使用都已经同步git 可以方便接入和使用。

4.  平台化  

埋点治理:如何把App埋点做到极致?

平台化部分

主要内容:

a)给App提供埋点日志上传接口服务

并且给测试提供可视化的验证页面,使得买点验证简单直观。

b)管理模块

给数据策略同学提供埋点增删改查服务,记录修改状态,使埋点管理高效便捷。

c)验证模块

埋点管理平台除了给App提供埋点 日志服务以外。

效果图如下:

埋点治理:如何把App埋点做到极致?

埋点管理模块

埋点治理:如何把App埋点做到极致?

埋点验证模块

总结

1. 切面化

通过拦截器,Aop等设计思想使手动埋点代码简单,兼容 ,埋点业务解耦

2. 动态化

通过LogParams,WMDA,动态埋点尽可能的使埋点动态化,避免发版,减少错误修复时间。

3. 平台化

通过埋点平台使数据,测试同学方便的管理,验证埋点,确保准确性。

展望与规划

现已上线多个版本,埋点问题有了明显的改善,部分埋点问题和需求可以不通过发版解决,埋点的开发效率提升50%,但依然存在一些问题需要提高。

1. 动态埋点覆盖性问题

因为是基于反射,只能保证调用方法的入参以及调用类的属性参数被获取,会存在一些参数没办法后获取到的问题,但是大部分情况没有问题

2. 动态埋点android混淆方案

Mapping文件的维护,版本控制等等体系还不健全,需要进一步完善和优化。

3. 验证的自动化部分

验证需要优化,自动化判空,自动化正则判断进一步提效 

现阶段埋点占比:手动埋点60%,WMDA20%,动态埋点20%

优化期望:手动埋点20%,WMDA40%,动态埋点40%

参考文献

1.58无埋点数据采集技术在Android端实践

2.安卓AOP三剑客:APT,AspectJ,Javassist

3.Android中的AOP编程之AspectJ实战实现数据埋点

4.《Android全埋点解决方案》

阅读推荐

1.独家|React Native 无限列表的优化与实践

2.小程序时代: 如何跨多小程序开发协作?

3.如何避免重复造轮子,打造一个属于自己的组件库?

4.基于有限状态机的广告状态管理方案及实现

5.58车商通RN落地与实践

埋点治理:如何把App埋点做到极致?


以上所述就是小编给大家介绍的《埋点治理:如何把App埋点做到极致?》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

让创意更有黏性

让创意更有黏性

[美] 奇普·希思、[美] 丹·希思 / 姜奕晖 / 中信出版社 / 2014-1-8 / 49.00元

你或许相信在太空中唯一能看到的人工建筑就是万里长城,可乐能腐蚀人体骨骼,我们的大脑使用了10%;与此同时,你却记不得上周例会上领导的安排,昨天看过的那本书里写了什么,上次参加培训的主要内容…… 为什么? 这就引发出《让创意更有黏性》的核心问题:什么样的观点或创意具有强有力的黏性,能被他人牢牢记住? 国际知名行为心理学家希思兄弟根据大量的社会心理学研究案例,揭示了让创意或观点具有黏......一起来看看 《让创意更有黏性》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器