Android mmap技术实现高性能日志库

现状:
(1)目前大家开发中打印日志不统一,有直接使用Android Log,也有使用封装的YmmLog(java),都没有打日志的习惯。
(2)定位线上问题没有辅助日志分析,不好定位,需要上传日志文件。
(3)目前中YmmLog库开发中频繁打日志保存文件的方式是java io实时写入文件,会导致IO频繁,影响性能。
(4)程序被系统杀掉,或者发生了 crash,crash 捕捉模块没有捕捉到导致部分时间点没有日志

技术目标:
1、C++实现高性能,Buffer缓存来减少IO次数,Native开发内存占用低,写入内存速度快,不卡顿
2、mmap实现crash,或进程退出时的未保存的log
3、日志上传辅助定位
4、密文保存日志,防止数据泄露
5、养成打日志的习惯,却不影响性能通过对比Mars Xlog 以及直接实时写入文件的方式的速度,截图如下:
场景:写入1000次,每次200个字节,耗时单位为ms

Mars Xlog
这里写图片描述

实时写文件java
这里写图片描述

YmmLog(C++)实现测试

这里写图片描述

对比结果:
(1)速度方面:YmmLog(C++)略大于XLog >>>java文件实时写入方式,
所耗时间如上图所示:40次点击,平均每次写入所耗时间(ms)为:143<183<<263
此时java方式还并没有加密,其他两种都已经封装好了对每条日志进行加密
(2)内存占用方便:YmmLog(C++)和Xlog只占用native内存,并保持低内存,基本不会影响内存太变化
(3)IO次数:YmmLog(C++)和Xlog次数只有buffer达到一定阀值才会异步写入文件,会远小于实时写入文件方式

猜你喜欢

转载自blog.csdn.net/u010019468/article/details/81027014