故障日志獲取
說明: 本模塊首批接口從API version 8開始支持。后續版本的新增接口,采用上角標單獨標記接口的起始版本。 開發前請熟悉鴻蒙開發指導文檔 :[
gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md
]
導入模塊
import faultLogger from '@ohos.faultLogger'
FaultType
故障類型枚舉。
系統能力: 以下各項對應的系統能力均為SystemCapability.HiviewDFX.Hiview.FaultLogger。
名稱 | 默認值 | 說明 |
---|---|---|
NO_SPECIFIC | 0 | 不區分故障類型 |
CPP_CRASH | 2 | C++程序故障類型 |
JS_CRASH | 3 | JS程序故障類型 |
APP_FREEZE | 4 | 應用程序卡死故障類型 |
FaultLogInfo
故障信息數據結構,獲取到的故障信息的數據結構。
系統能力: 以下各項對應的系統能力均為SystemCapability.HiviewDFX.Hiview.FaultLogger。
名稱 | 參數類型 | 說明 |
---|---|---|
pid | number | 故障進程的進程id |
uid | number | 故障進程的用戶id |
type | [FaultType] | 故障類型 |
timestamp | number | 日志生成時的秒級時間戳 |
reason | string | 發生故障的原因 |
module | string | 發生故障的模塊 |
summary | string | 故障的概要 |
fullLog | string | 故障日志全文 |
faultLogger.querySelfFaultLog
querySelfFaultLog(faultType: FaultType, callback: AsyncCallback>) : void
獲取當前進程故障信息,該方法通過回調方式獲取故障信息數組,故障信息數組內最多上報10份故障信息。
系統能力: SystemCapability.HiviewDFX.Hiview.FaultLogger
參數:
參數名 | 類型 | 必填 | 說明 |
---|---|---|---|
faultType | [FaultType] | 是 | 輸入要查詢的故障類型。 |
callback | AsyncCallbackArray> | 是 | 回調函數,在回調函數中獲取故障信息數組。 - value拿到故障信息數組;value為undefined表示獲取過程中出現異常,error返回錯誤提示字符串 |
示例:
function queryFaultLogCallback(error, value) {
if (error) {
console.info('error is ' + error);
} else {
console.info("value length is " + value.length);
let len = value.length;
for (let i = 0; i < len; i++) {
console.info("log: " + i);
console.info("Log pid: " + value[i].pid);
console.info("Log uid: " + value[i].uid);
console.info("Log type: " + value[i].type);
console.info("Log timestamp: " + value[i].timestamp);
console.info("Log reason: " + value[i].reason);
console.info("Log module: " + value[i].module);
console.info("Log summary: " + value[i].summary);
console.info("Log text: " + value[i].fullLog);
}
}
}
faultLogger.querySelfFaultLog(faultLogger.FaultType.JS_CRASH, queryFaultLogCallback);
faultLogger.querySelfFaultLog
querySelfFaultLog(faultType: FaultType) : Promise>
獲取當前進程故障信息,該方法通過Promise方式返回故障信息數組,故障信息數組內最多上報10份故障信息。
系統能力: SystemCapability.HiviewDFX.Hiview.FaultLogger
參數:
參數名 | 類型 | 必填 | 說明 |
---|---|---|---|
faultType | [FaultType] | 是 | 輸入要查詢的故障類型。 |
返回值:
類型 | 說明 |
---|---|
Promise> | Promise實例,可以在其then()方法中獲取故障信息實例,也可以使用await。 - value拿到故障信息數組;value為undefined表示獲取過程中出現異常HarmonyOS與OpenHarmony鴻蒙文檔籽料:mau123789是v直接拿 |
示例:
async function getLog() {
let value = await faultLogger.querySelfFaultLog(faultLogger.FaultType.JS_CRASH);
if (value) {
console.info("value length is " + value.length);
let len = value.length;
for (let i = 0; i < len; i++) {
console.info("log: " + i);
console.info("Log pid: " + value[i].pid);
console.info("Log uid: " + value[i].uid);
console.info("Log type: " + value[i].type);
console.info("Log timestamp: " + value[i].timestamp);
console.info("Log reason: " + value[i].reason);
console.info("Log module: " + value[i].module);
console.info("Log summary: " + value[i].summary);
console.info("Log text: " + value[i].fullLog);
}
}
}
審核編輯 黃宇
-
開發系統
+關注
關注
0文章
38瀏覽量
9681 -
鴻蒙
+關注
關注
57文章
2350瀏覽量
42843
發布評論請先 登錄
相關推薦
評論