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
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...