這麼分析大文件日誌,以後就不用加班捲了!

来源:https://www.cnblogs.com/programmingBB/archive/2023/05/17/17407405.html
-Advertisement-
Play Games

有沒有熟悉這樣的場景: 時間已過十一點,空蕩蕩的辦公室只剩自己孤身一人。陪你伏案忙碌的只有電腦風扇被迫營業的“嗡嗡”聲, 窗外的夜正黑得帶勁,仿佛巨獸的口吞噬自己的無奈。 天性善良不善言辭的你,容易被人頤指氣使,加班對你來說是家常便飯。 作為一名碼農,“我到底哪裡錯了,我需要怎麼解決?”是我的座右銘 ...


有沒有熟悉這樣的場景:

時間已過十一點,空蕩蕩的辦公室只剩自己孤身一人。陪你伏案忙碌的只有電腦風扇被迫營業的“嗡嗡”聲, 窗外的夜正黑得帶勁,仿佛巨獸的口吞噬自己的無奈。

天性善良不善言辭的你,容易被人頤指氣使,加班對你來說是家常便飯。

作為一名碼農,“我到底哪裡錯了,我需要怎麼解決?”是我的座右銘。但是,解決問題的過程需要耐心和細心,需要在大文件日誌中尋找問題線索,耗費巨量的時間和精力。因此,加班分析並解決問題是常有的事情。

有時候想,如果分析日誌過程能高效,是不是就可以減少無意義的班?節約出來的時間老婆孩子熱炕頭豈不美哉。

本文介紹的 Notepad++ 和 AnalysePlugin 絕妙組合,在分析大文件日誌上大放異彩,簡直是“神兵利器”,特別對初入職場的碼農,文字或者數據統計相關從業人員特別有用。職場老手應該都會有自己的獨家秘籍,見仁見智,沒有標準答案,能達成目標即好方法。文章是本人經驗總結,不喜勿噴,歡迎多多留言關註,謝謝~~~

話不多說,本文重點講解如何使用 Notpad++ 配合 AnalysePlugin 分析大文件日誌,找到目標日誌信息。

存在問題

大文件日誌分析,我們需要一次性搜索多個關鍵字,將面臨兩個問題。

一. 多日誌文件,不知道關鍵字在哪些文件里

面對幾個 GB 的大文件日誌,例如安卓系統應用出現無響應問題時,系統會自動生成多個異常跟蹤文件並自動保存,導致存在過多的日誌文件。

如何找到關註日誌在哪個文件呢?

通常的過程是這樣的:

for(int i = 1 ; i <= 日誌文件數目;++i){
   1. 打開單個日誌文件
   2. bool result = ctrl + F 搜索目標關鍵字
   if(result){
      3. 保存。
   }
   4. 獲取保存所有帶目標關鍵字日誌
   for(int j = 1 ; j <= 目標關鍵字日誌數目;++j){
      5. 打開初步文件看是否存在有用信息,定位問題。
   }
}

是不是有點像大海撈針的感覺?

打開所有的日誌文件,然後一個個查看是不是目標日誌文件。該方法肯定可行,無非就是多花點時間。

只要方法是對的,總可以完成。然而,你有沒有想過,憑啥這種“不用腦子”的體力活要你乾?爺的時間就這麼不值錢嗎?有這時間刷刷劇,打把游戲不香嗎?

二.無法有重點的分析日誌

舉個例子,我們需要在日誌文件中查找 "onLayout"、"SQLiteLog"、"java.lang.RuntimeException",以定位問題。在關註日誌時,我們需要註意以下幾點:

  1. 如果應用程式崩潰了,我們會重點關註 "java.lang.RuntimeException"。
  2. 如果沒有發現 "RuntimeException",則可能會關註與 "SQLiteLog" 相關的警告。
  3. 如果甚至連繫統警告都沒有,那麼只能查看與應用程式相關的 "onLayout" 日誌。

通常的做法是直接搜索關鍵字,這樣做雖然可行,但給人的感覺不夠直觀。由於屏幕小且高度近視,搜索結果都是一堆黃色的漿糊,無法有效區分日誌級別,不利於重點突出地分析問題。

如下在Notepad++中的搜索結果,只要是關鍵字都是黃色。

一般的處理思路是,將就著看就行,別沒事找事。被子反正第二天會睡不好,索性不疊了~~~,哈哈!

不過,碼農應該都有潔癖,長期沉浸在祖傳的“屎山”中,增刪改查,誰不都會說:“我去,垃圾代碼!”如果是我,我會怎麼怎麼做。

看吧,是個人都不會將就,如果有更好的選擇

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

-Advertisement-
Play Games
更多相關文章
  • 在VB.NET中,您可以使用Substring方法或Split方法來截取字元串。 Substring方法允許您從字元串中提取一個子字元串,該子字元串從指定的起始索引開始,並繼續到字元串的末尾或指定的長度。以下是使用Substring方法截取字元串的示例: Dim str As String = "H ...
  • JwtBearer簡介 首先要搞清楚什麼是JwtBearer,JwtBearer是ASP.NET Core的OAuth 2.0 JWT Bearer身份驗證提供程式。它提供了對JWT令牌進行驗證的功能,然後允許將令牌中包含的聲明(claims)用於用戶身份驗證和授權控制。 Json Web Toke ...
  • 一:背景 1. 講故事 前幾天有位朋友找到我,說他們的軟體在客戶那邊卡死了,讓我幫忙看下是怎麼回事?我就讓朋友在程式卡死的時候通過 任務管理器 抓一個 dump 下來,雖然預設抓的是 wow64 ,不過用 soswow64.dll 轉還是可以的,參考命令如下: .load C:\soft\soswo ...
  • Ubuntu忘記密碼(五個小步驟) 可能用到的操作: | 按鍵/滑鼠操作 | 作用 | | | | | 進入虛擬機屏幕[點擊] | 滑鼠焦點在虛擬機中,接下來的操作都在虛擬機中響應 | | 退出虛擬機屏幕[ctrl+alt] | 將滑鼠焦點從虛擬機中移除,回到主屏幕 | 步驟一:重啟虛擬機,註意在= ...
  • 近日發現PG官方插件列表中新收錄了一款插件 pg_enterprise_views,因為官方已經數年未添新的插件了很是新奇,找了台設備測試過後果斷上了生產,得空分享給大家。 該插件提供了數十張系統表及一個GUI工具,用以監控從操作系統到資料庫方方面面的性能情況,並支持對任意時段歷史數據的回溯,基本等 ...
  • hive入門到精通 hive部署 啟動Hadoop # 啟動hadoop start-all.sh # 檢查hadoop進程 jps # 檢查各埠 netstat -aplnt | grep java 檢查MySQL是否啟動成功 ps -aux | grep mysql netstat -apln ...
  • 一直從事資料庫相關的工作,對於PG而言最大的問題其實是在運維管理方面,其缺乏有效且直觀成體系的系統表,苦覓良久,今日在PG官網中發現了一款新收錄的免費插件,其提供了數十張系統表,內容涵蓋了從操作系統到資料庫的負載指標、等待事件、會話、客戶端、SQL、SQL執行計劃、超時鎖、長事務、資料庫對象、寫進程 ...
  • MySQL 8.0.28引入的新功能 MySQL 8.0.28開始,新增一個特性,支持監控統計並限制各個連接(會話)的記憶體消耗,避免大量用戶連接因為執行垃圾SQL消耗過多記憶體,造成可能被OOM kill的風險。 首先,需要先設置系統選項 global_connection_memory_tracki ...
一周排行
    -Advertisement-
    Play Games
  • 人臉識別技術在現代社會中扮演著越來越重要的角色,比如人臉識別門禁、人臉識別支付、甚至人臉識別網站登錄等。 最近有群友問.NET有沒有人臉識別的組件,小編查閱相關資料介紹下麵幾種.NET人臉識別組件供大家參考。 **1、Microsoft Azure Face API** 簡介:Microsoft A ...
  • # 1. 與 .NET Core 緩存的關係和差異 ABP 框架中的緩存系統核心包是 [Volo.Abp.Caching](https://www.nuget.org/packages/Volo.Abp.Caching) ,而對於分散式緩存的支持,abp 官方提供了基於 Redis 的方案,需要安裝 ...
  • 最近ET做熱更重載dll的時候,返回登陸會重新檢測新的dll,首次登錄之前已經Assembly.Load()過一次dll,第二次返回登陸再次load dll到記憶體中,Invoke執行方法的時候,異常了,有些方法執行了,有些未執行,於是查資料,看到些老資料說Assembly.Load重覆載入同名dll ...
  • 1. 擴展方法 擴展方法使你能夠向現有類型“添加”方法,而無需創建新的派生類型、重新編譯或以其他方式修改原始類型。 擴展方法是一種靜態方法,但可以像擴展類型上的實例方法一樣進行調用。 對於用 C#、F# 和 Visual Basic 編寫的客戶端代碼,調用擴展方法與調用在類型中定義的方法沒有明顯區別 ...
  • 以前在隨筆《Winform開發框架之客戶關係管理系統(CRM)的開發總結系列1-界面功能展示 》的幾篇隨筆中介紹過基於WInform開發框架開發的CRM系統,系統的功能主要也是圍繞著客戶相關信息來進行管理的。本篇隨筆介紹在最新的《SqlSugar開發框架》中整合CRM系統模塊的功能。 ...
  • 隨著技術的發展,ASP.NET Core MVC也推出了好長時間,經過不斷的版本更新迭代,已經越來越完善,本系列文章主要講解ASP.NET Core MVC開發B/S系統過程中所涉及到的相關內容,適用於初學者,在校畢業生,或其他想從事ASP.NET Core MVC 系統開發的人員。 經過前幾篇文章... ...
  • [toc] 這篇文章是我之前總結的一篇文章,因為整理博客的原因,原有博客已經註銷,但這篇文章對一些讀者很有用,所以現在新瓶裝舊酒重新整理回來分享給大家。 最近一段時間生產環境頻繁出問題,每次都會生成一個hs_err_pid*.log文件,因為工作內容的原因,在此之前並沒有瞭解過相關內容,趁此機會學習 ...
  • # 前言 在上一篇文章中,給大家講解了泛型的概念、作用、使用場景,以及泛型集合、泛型介面和泛型類的用法,但受限於篇幅,並沒有把泛型的內容講解完畢。所以今天我們會繼續學習泛型方法、泛型擦除,以及通配符等的內容,希望大家繼續做好學習的準備哦。 *** 全文大約【**4600】** 字,不說廢話,只講可以 ...
  • 昨天遇到參數key大小寫不一致導致校驗簽名失敗的問題,查了很長時間才找到原因。看了一下FastJson源碼,發現JSON.toObject中轉換成對象的時候會忽略大小寫。 所以,當使用了JSON.toObject將json轉成Java對象後,再用JSON.toObject轉成json,key值就變了 ...
  • 基於java的線上商城設計與實現,線上購物平臺,校園購物商城,商品銷售平臺,基於Java的電商平臺;電商平臺,買家和賣家可以在此平臺上進行銷售和交易,節約了大量的線下時間成本,購物車的功能,校園交易平臺等等; ...