iOS閃退日誌的收集和解析

来源:https://www.cnblogs.com/jingxin1992/archive/2020/02/21/12342168.html
-Advertisement-
Play Games

在開發過程中往往會遇見有個別用戶或者測試人員反饋app的閃退現象,而項目一般集成的統計閃退的第三方庫是籠統的統計了所有的閃退信息,無法去定位某一個用戶提出的某一個時間點的某一個閃退問題,於是乎這個時候需要我們能快速的去獲取指定用戶提出的指定閃退,並能夠解析閃退日誌,快速的定位到問題。下麵將自己的做法 ...


  在開發過程中往往會遇見有個別用戶或者測試人員反饋app的閃退現象,而項目一般集成的統計閃退的第三方庫是籠統的統計了所有的閃退信息,無法去定位某一個用戶提出的某一個時間點的某一個閃退問題,於是乎這個時候需要我們能快速的去獲取指定用戶提出的指定閃退,並能夠解析閃退日誌,快速的定位到問題。下麵將自己的做法大概的做個總結(可能還有別的方法,但是我覺得下麵講述的方法已經足夠了)。

一、收集閃退日誌

  先和用戶確定iPhone是否打開如下設置(以iOS12.0的iPhone為參考):

  設置->隱私->分析->共用iPhone分析->與應用開發者共用

  只有打開了上述設置閃退日誌才會被收集,然後進入設置->隱私->分析->分析數據,找到以自己項目開頭拼接出現閃退大致時間點文件名的ips文件。

 

 

二、解析閃退日誌

  1.如果還能找到用戶反饋有問題的app 當時打包時相對應的項目源碼,那麼就很簡單了

  獲取到的.ips文件雙擊打開是沒有解析的日誌,現在需要修改尾碼名為.crash,然後雙擊打開出現下麵的彈窗

可以選中當時打包的項目,預覽並且打開,這時候你會發現打開後的項目會顯示閃退的地方。

 

 

 

   沒錯,就是這麼簡單。不過前提條件是你還有當時打包的項目源碼,不然要是用改動過當前閃退所在文件的源碼,定位的位置是不對的。

  2.不能找到打包時的項目源碼,但是可以找到當時打包的dSYM文件

具體步驟:

1.首先在桌面新建一個文件夾crashFile,用於存放解析閃退日誌用到的文件。

2.找到前面獲取到的.ips文件,拷貝.ips文件放到crashFile中

3.獲取symbolicatecrash文件。

找到當時打包所用的xcode(可能筆記本安裝了好幾個Xcode),然後進入下麵的路徑:/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash

拷貝symbolicatecrash工具拷貝到crashFile中

4.獲取dSYM文件

從當時打包的xcode->Window->Organizer->Archives找到當時的xcarchive文件,選中xcarchive文件右鍵點擊【顯示包內容】,拷貝dSYMs文件下的.dSYM文件,放到crashFile中。

至此,crashFile文件中總共有3個文件:.ips文件、symbolicatecrash工具、.dSYM文件。

5. 打開終端,cd到crashFile文件夾中

6. 輸入命令

./symbolicatecrash Agent-2020-02-21-124913.ips Agent.app.dSYM > crash.log

這時候會發現crashFile文件夾下多了個crash.log文件

 

 

雙擊打開crash.log文件,你會發現崩潰信息已經成功解析

好了,大功告成!!!

下麵將附上參考的地址(可以驗證閃退的ips文件和dsym文件對應的app是否是同一個):

https://www.cnblogs.com/mukekeheart/p/9449189.html

https://hacpai.com/article/1533042075262

https://www.jianshu.com/p/e5ad706e4196

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在SQL Server Management Studio對象,會隨系統的開發,所產生的對象也會越來越多,我們可以使用SMS的過濾功能來查找對象: 參考下麵步驟: 按步驟5之後,得到結果: 最後,如果想取消過濾,參考: ...
  • 準備一些數據,創建2張表,表1為學生表: CREATE TABLE [dbo].[Student] ( [SNO] INT NOT NULL PRIMARY KEY, [Name] NVARCHAR(10) NOT NULL, [Performance] DECIMAL(18,2) NULL ) G ...
  • At most Onece:最多一次,如果運算元處理事件失敗,事件將不再嘗試該事件。 At Least Onece:至少一次,如果運算元處理事件失敗,運算元會再次嘗試該處理事件,直到有一次成功。 Exactly Once:嚴格一次,通常有兩種方法實現: 1.分散式快照+狀態檢查點,思想就是對比檢查點和分佈 ...
  • 大致可以將大數據的計算引擎分成了 4 代。 1、第一代的計算引擎,無疑就是Hadoop承載的MapReduce。它將每個JobApp都被設計為兩個階段,分別為Map和Reduce。對於上層應用來說,就不得不想方設法去拆分演算法,甚至於不得不在 上層應用實現多個App的串聯 ,才能完成一個完整的演算法,例 ...
  • 關於SQL Server資料庫中的對象命名的唯一性問題。例如表、索引、約束等資料庫對象,有時候DBA在做資料庫維護時,經常要創建對象或重命名對象,此時就會遇到一個問題,對象命名的唯一性問題。雖然是一個小小的問題,估計不少人搞不清,在看文章前,你可以先回答幾個問題 1: 表名在資料庫是不是唯一? 不同... ...
  • 起因: 因工作需要,在本機測試環境升級mysql資料庫,需逐條執行mysql資料庫的sql文件對資料庫進行升級,因此找了些關於mysql的文章,對批量升級資料庫所需的sql文件進行升級。 整理思路: 首先,需要對所需升級的sql所在目錄的sql文件進行遍歷。生成新的批量執行sql文件。想到是wind ...
  • 參考: DECLARE @D DATETIME = GETDATE() SELECT DATEPART(YEAR,@D) AS [YEAR], DATEPART(MONTH,@D) AS [MONTH], DATEPART(DAY,@D) AS [DAY] SELECT YEAR(@D) AS [Y ...
  • 資料庫日期簡單加或減: DECLARE @D DATETIME = GETDATE() SELECT @D SELECT DATEADD(DAY,5,@D) --加5天 SELECT DATEADD(DAY,-5,@D) --減5天 --簡單加減,如: SELECT @D + 5 SELECT @D ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...