Android平台日志收集系统

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: Android平台日志收集系统      在产品开发测试中以及产品投放到终端客户后,我们经常会遇到各种各样的问题,产品出异常,比较严重的就是使用过程中死机,用户无法操作。

Android平台日志收集系统


      在产品开发测试中以及产品投放到终端客户后,我们经常会遇到各种各样的问题,产品出异常,比较严重的就是使用过程中死机,用户无法操作。对于这种情况,将问题反馈给研发,问题能够快速重现的研发还比较好解决,有些问题不常见,研发短时间内也很难找到问题根源。为了提高研发的效率,那么每次出异常的时候我们都最好有系统的打印系统,通过系统打印异常的蛛丝马迹去查找问题的元凶。但是有时出问题的时候,系统都已经死机或者无法操作了,也就不能通过操作去抓系统打印了,因此引入日志收集系统就变得很有必要。日志收集系统每次系统启动后后台自动运行,直至关机或系统崩溃,因此可以全程守护监控系统打印,对产品的快速稳定有着非常重要的意义。

        日志,在Android系统中我们需要抓取的主要有两部分,一部分是驱动内核

打印出来的,一部分就是android部分打印出来的。

      驱动内核打印的信息查看方法:cat /proc/kmsg

      Android部分打印信息查看方法:logcat -v time


    日志系统运行逻辑

1、日志系统需要自动运行,无需人工干预;

2、如果用户通过系统持续抓取打印信息功能,需视日志系统是否已经启动,如果日志系统已经启动,那么可以提示用户日志系统已经启动;如果未启动,那么可以手动启动系统持续抓取系统打印功能;

3、什么时候自动启动日志系统?

 从实际使用情况来说可以分一下几种情况:

A、        如果用户已经手动启动了持续抓取系统打印信息功能,此次开机无需再启动日志系统;

B、        卫星未定位,在收到系统BOOT_COMPLETED消息后30秒,启动日志收集系统。

4、日志系统空间大小限制;

     鉴于每次系统启动后的正常打印,按照每次开机后运行的打印信息在3MB左右,按照平均每天用户开关机5次的使用频率,那么正常情况下一天就需要15MB空间,按照运行7天的收集限制,把存放日志系统文件的目录大小限制为100MB,在每次启动日志系统前,判断该目录是否已经达到100M,如果已经达到,那么可以启动删除程序删除日期最早存入的日志文件,一次删除达到30MB为宜,周而复始,循环操作,日志系统文件存储在系统内部,也就是/sdcard目录下,目录定在/sdcard/savelog。

      当savelog目录文件大小超过100MB的情况下,我们需要判断一下里面是否有异常文件,在此暂且认为单次存入文件大小超过20MB的打印信息文件为系统异常的主要参考;那么怎么处理呢?按以下步骤处理:

     第一步、压缩该异常文件,可以使用tar工具,压缩后的包可以存放到/sdcard/tarlog目录,该目录最多存6份异常信息,达到6份时,一次性删除前三次异常;

     第二步、异常信息的压缩包通过网络传回服务器;这里分两种情况,一种在不带4G模块的机器,将通过用户在打开车智享的时候,通过车智享的程序与机器日志系统通讯判断是否有异常信息需要上报,如果有,一次最多从异常信息目录传递3个压缩包,然后车智享程序判断用户网络环境为WIFI的情况下,跟服务器通讯,把异常信息压缩包传递到服务器。另外一种就是带4G通讯模块的,那么就无需车智享中转,直接从机器端上传到服务器。

     第三步、服务器开发维护人员将收集到的异常信息包拷贝出来给研发工程师分析。

5、人工参与提取系统日志系统打印:

     由于日志系统是存储在系统内部存储里面,因此我们在使用的时候需要把需要的日志文件拷贝到DVR卡,再反馈到研发。

开发、测试人员:可以直接通过文件管理器去到/sdcard/savelog目录去拷贝需要的日志文件到DVR卡或者U盘,这个比较便利,平时使用较多,相关人员稍作培训即可。

但是对于终端客户可能不知道怎么找对应的日志文件,因此我们需要傻瓜式一点。初步方案云服务程序里增加【用户体验反馈】按钮,点击该按钮后弹出让用户选择异常出现的大概时间段,是一个相对模糊一点的,可供选择的时间将是最1天、最近3天、最近5天,那么系统将会把对应时段收集到的系统打印信息打成压缩包后通过云服务上传到服务器,然后再把压缩包提交给研发工程师分析,该压缩包名称:电子条码+系统版本号组成,跟进电子条码可以找到对应终端用户,必要的时候可以电话沟通获取更详细的使用场景,系统版本号可以直观的帮助我们定位软件发布的时段,对跟进解决问题都有很大的帮助

       6、当文件序列号达到9999时,全部删除保存的log,重新从0000开始计数。假如一套开机十次,序列号运行到9999需要1000天。

     一套有效的后台log系统对研发的帮助还是蛮大的,在嵌入式产品中也要尽量支持这种功能,可以加快研发进度,提高研发质量。


相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
1月前
|
人工智能 搜索推荐 物联网
Android系统版本演进与未来展望####
本文深入探讨了Android操作系统从诞生至今的发展历程,详细阐述了其关键版本迭代带来的创新特性、用户体验提升及对全球移动生态系统的影响。通过对Android历史版本的回顾与分析,本文旨在揭示其成功背后的驱动力,并展望未来Android可能的发展趋势与面临的挑战,为读者呈现一个既全面又具深度的技术视角。 ####
|
22天前
|
IDE 开发工具 Android开发
移动应用开发之旅:探索Android和iOS平台
在这篇文章中,我们将深入探讨移动应用开发的两个主要平台——Android和iOS。我们将了解它们的操作系统、开发环境和工具,并通过代码示例展示如何在这两个平台上创建一个简单的“Hello World”应用。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和技巧,帮助你更好地理解和掌握移动应用开发。
50 17
|
1月前
|
IDE Java 开发工具
移动应用与系统:探索Android开发之旅
在这篇文章中,我们将深入探讨Android开发的各个方面,从基础知识到高级技术。我们将通过代码示例和案例分析,帮助读者更好地理解和掌握Android开发。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和技巧。让我们一起开启Android开发的旅程吧!
|
22天前
|
监控 Java Android开发
深入探索Android系统的内存管理机制
本文旨在全面解析Android系统的内存管理机制,包括其工作原理、常见问题及其解决方案。通过对Android内存模型的深入分析,本文将帮助开发者更好地理解内存分配、回收以及优化策略,从而提高应用性能和用户体验。
|
24天前
|
存储 安全 Android开发
探索Android系统的最新安全特性
在数字时代,智能手机已成为我们生活中不可或缺的一部分。随着技术的不断进步,手机操作系统的安全性也越来越受到重视。本文将深入探讨Android系统最新的安全特性,包括其设计理念、实施方式以及对用户的影响。通过分析这些安全措施如何保护用户免受恶意软件和网络攻击的威胁,我们希望为读者提供对Android安全性的全面了解。
|
2月前
|
缓存 Java Shell
Android 系统缓存扫描与清理方法分析
Android 系统缓存从原理探索到实现。
83 15
Android 系统缓存扫描与清理方法分析
|
25天前
|
存储 监控 安全
什么是事件日志管理系统?事件日志管理系统有哪些用处?
事件日志管理系统是IT安全的重要工具,用于集中收集、分析和解释来自组织IT基础设施各组件的事件日志,如防火墙、路由器、交换机等,帮助提升网络安全、实现主动威胁检测和促进合规性。系统支持多种日志类型,包括Windows事件日志、Syslog日志和应用程序日志,通过实时监测、告警及可视化分析,为企业提供强大的安全保障。然而,实施过程中也面临数据量大、日志管理和分析复杂等挑战。EventLog Analyzer作为一款高效工具,不仅提供实时监测与告警、可视化分析和报告功能,还支持多种合规性报告,帮助企业克服挑战,提升网络安全水平。
|
1月前
|
监控 Java Android开发
深入探讨Android系统的内存管理机制
本文将深入分析Android系统的内存管理机制,包括其内存分配、回收策略以及常见的内存泄漏问题。通过对这些方面的详细讨论,读者可以更好地理解Android系统如何高效地管理内存资源,从而提高应用程序的性能和稳定性。
70 16
|
1月前
|
前端开发 数据处理 Android开发
Flutter前端开发中的调试技巧与工具使用方法,涵盖调试的重要性、基本技巧如打印日志与断点调试、常用调试工具如Android Studio/VS Code调试器和Flutter Inspector的介绍
本文深入探讨了Flutter前端开发中的调试技巧与工具使用方法,涵盖调试的重要性、基本技巧如打印日志与断点调试、常用调试工具如Android Studio/VS Code调试器和Flutter Inspector的介绍,以及具体操作步骤、常见问题解决、高级调试技巧、团队协作中的调试应用和未来发展趋势,旨在帮助开发者提高调试效率,提升应用质量。
52 8
|
29天前
|
安全 Android开发 iOS开发
深入探讨Android与iOS系统的差异及未来发展趋势
本文旨在深入分析Android和iOS两大移动操作系统的核心技术差异、用户体验以及各自的市场表现,进一步探讨它们在未来技术革新中可能的发展方向。通过对比两者的开放性、安全性、生态系统等方面,本文揭示了两大系统在移动设备市场中的竞争态势和潜在变革。