mPaas从埋点排查iOS离线包问题

本文涉及的产品
mPaaS订阅基础套餐,标准版 3个月
日志服务 SLS,月写入数据量 50GB 1个月
简介: 随着mPaaS的用户量的不断加大,越来越多的客户使用到了框架的核心功能《离线包》, 官方文档给到的离线包的加载流程范围比较大,没那么细节,客户遇到离线包的问题时不知道如何去下手排查,所以需要更详细的加载流程协助客户排查问题。

一、背景

随着mPaaS的用户量的不断加大,越来越多的客户使用到了框架的核心功能《离线包》, 官方文档给到的离线包的加载流程范围比较大,没那么细节,客户遇到离线包的问题时不知道如何去下手排查,所以需要更详细的加载流程协助客户排查问题。


二、原理

以一次启动离线宝的流程为例,离线包的加载流程分为两种场景,第一种是离线包下载好的场景,流程如图1所示,第二种是离线包没下载好的场景,如图2所示。

                                          图1: 离线包加载主流

                                  图2: 离线包下载流程

我们可以从埋点来跟踪离线包具体的加载流程:

离线包日志埋点

1、检查本地是否有离线包,本地有则执行第四步解压,解压之后再进行校验,校验通过加载本地离线包,如果本地已经安装过,那就不需要解压直接走解压后的流程

2、网络请求离线包信息,这一步和上一步是异步进行的,对应的埋点有H5_APP_REQUEST

3、对比请求回来的离线包信息,再决定是否下载离线包,对应的埋点有H5_APP_DOWNLOAD

4、解压离线包,对应的埋点有H5_APP_UNZIP

5、如果开启了离线包验签,校验离线包的合法性,对应的埋点有H5_APP_VERIFY、H5_AL_SESSION_VERIFYTAR_FAIL

6、加载本地离线包,对应的埋点有H5_AL_SESSION_MAP_SUCCESS、H5_AL_SESSION_FALLBACK


注意:fallback走线上需要等到离线包请求这个异步请求回调回来之后返回的fallback + mainUrl确定webview打开的URL

三、案例

案例1:首次打开离线包白屏

1、按照离线包加载流程分析,首次打开离线包一定是需要走线上的fallback,因为本地没有,走线上之前一定需要先知道离线包的线上地址也就是URL,所以需要查看日志分析是否是请求离线包信息那一步出错了

2、分析日志打开线上离线包的时候URL为空,在离线包请求还没有回调回来之前就打开离线包,所以出现了白屏

3、检查代码

将创建的离线包控制器作为根视图,时机过早,所以导致了该问题

4、结合客户需求给出建议,可以使用本地预制离线包解决首次过早打开离线包出现白屏的问题

案例2:打开预制离线包,页面显示网络无法连接(-1009)

复现demo📎打开预制离线包错误.zip

1、断网情况下打开预制离线包失败显示网络无法连接说明打开预制包失败了,所以走了线上,由于没有网络所以显示网络无法连接,问题出在本地预制的离线包上

2、按照离线包的加载流程分析,在本地有预制包的情况下出现走线上的情况分别有2种情况,离线包验证签名失败和加载本地离线包失败

3、日志分析

观察到有验签失败的字样

4、检查代码客户端是否关闭了验签,默认是开启的,如果没有关闭,那么客户端需要设置对应的公钥,或者关闭验签

5、关闭验签再试一遍,继续分析日志

H5_AL_SESSION_FALLBACK加载本地离线包失败,最终走的线上,观察解压离线包成功没有问题,问题出在加载离线包那一步,日志中查找到H5_APP_EXCEP离线包异常埋点,是读取数据时候失败了

6、问题有可能出现在该离线包上面,所提供一个正常的离线包给客户做成本地预制离线包,断网打开验证,没有问题,问题就出在该离线包上

7、解开预制的离线包,观察离线包是否路径字符总长度是否超过了限制导致读取数据失败

JS文件名称过长,导致总的字符长度超过了限制,需要客户修改离线包

四、思考和总结

通过上面2个案例的介绍,我们可以清晰的看到案例一最终出现问题的原因是请求离线包信息这个请求没有回调回来,客户就打开离线包时没有获取到URL,问题出现在了请求离线包那一步了,而案例二最终定位到加载本地包失败那一步,了解了离线包的具体加载流程,再结合nebula容器自动化埋点日志,就可以具体定位问题到离线包加载的哪一步了。

相关文章
|
5月前
|
安全 开发者 iOS开发
iOS16系统手机设置开启开发者模式才能安装ipa包
iOS16系统手机设置开启开发者模式才能安装ipa包
194 1
|
5月前
|
Android开发 数据安全/隐私保护 iOS开发
ios和安卓测试包发布网站http://fir.im的注册与常用功能
ios和安卓测试包发布网站http://fir.im的注册与常用功能
241 0
ios和安卓测试包发布网站http://fir.im的注册与常用功能
|
5月前
|
自然语言处理 程序员 开发工具
iOS生成Bundle 资源文件包与使用
iOS生成Bundle 资源文件包与使用
152 0
|
5月前
|
数据安全/隐私保护 Android开发 iOS开发
如何发布ios离线安装包
如何发布ios离线安装包
58 0
|
5月前
|
Linux iOS开发 开发者
ios ipa包上传需要什么工具
ios ipa包上传需要什么工具
44 0
|
5月前
|
移动开发 监控 小程序
mPaaS常见问题之uniapp ios端云打包的配置config文件如何解决
mPaaS(移动平台即服务,Mobile Platform as a Service)是阿里巴巴集团提供的一套移动开发解决方案,它包含了一系列移动开发、测试、监控和运营的工具和服务。以下是mPaaS常见问题的汇总,旨在帮助开发者和企业用户解决在使用mPaaS产品过程中遇到的各种挑战
168 0
|
5月前
|
缓存 小程序 Android开发
mPaaS问题之iOS调用插件的时候提示没有配置mpaas. Config文件如何解决
mPaaS配置是指在mPaaS平台上对移动应用进行的各项设置,以支持应用的定制化和优化运行;本合集将提供mPaaS配置的操作指南和最佳实践,助力开发者高效管理和调整移动应用的设置。
121 1
|
5月前
|
Web App开发 小程序 Android开发
mPaaS小程序问题之接入iOS后阿里百川初始化报错如何解决
mPaaS小程序是阿里巴巴移动平台服务(mPaaS)推出的一种轻量级应用解决方案,旨在帮助开发者快速构建跨平台的小程序应用;本合集将聚焦mPaaS小程序的开发流程、技术架构和最佳实践,以及如何解决开发中遇到的问题,从而助力开发者高效打造和维护小程序应用。
112 1
|
5月前
|
小程序 Android开发 iOS开发
mPaaS问题之Ios调小程序报错如何解决
mPaaS小程序是阿里巴巴移动平台服务(mPaaS)推出的一种轻量级应用解决方案,旨在帮助开发者快速构建跨平台的小程序应用;本合集将聚焦mPaaS小程序的开发流程、技术架构和最佳实践,以及如何解决开发中遇到的问题,从而助力开发者高效打造和维护小程序应用。
mPaaS问题之Ios调小程序报错如何解决
|
5月前
|
Linux iOS开发 开发者
ios ipa 包上传需要什么工具
ios ipa 包上传需要什么工具