打日誌還能打出個線上Bug_ 太難了。。。

某日中午,收到告警,有一筆訂單下單失敗了。趕緊去Cat看了下錯誤信息,如下:

Web應用調用訂單服務的RPC接口報錯了,一看錯誤很自主的認爲這是一個序列化的問題。後面排查下來發現壓根就不是,這個錯誤報的有點。。。

想着是不是參數中有什麼特別的東西,然後發現也沒有什麼特別的。這個錯誤是某個商品下單纔會出現,不是所有的商品都會出現這個問題。

然後嘗試在本地復現,有這麼一行關鍵的代碼,貼了一部分,完整的作用是埋點打日誌。

String.format("UnifiedOrderServiceImpl.makeOrder創建訂單, make order, request: MakeOrderRequest= "+ request)
說實話我是沒看懂這裏用String.format的原因在哪裏,不就是想拼接個字符串麼?還搞個format,搞就搞嘛,還沒用佔位符,騷操作。

真正Bug的原因是request對象中有個String類型的字段,字段裏面的內容有%\,format內部就報錯了,大家可以用下面這段代碼復現錯誤:

public static void main(String[] args) {
String.format("dsdsdsd"+"%\sdsd");
}
錯誤信息:

Exception in thread "main" java.util.UnknownFormatConversionException: Conversion = ''
原因是在format中會校驗參數,然後觸發了異常。

雖然是很小的改動,就記錄個日誌而已,但也不要輕視,往往就是不夠仔細,然後纔會出這種問題。

總結:

認真對待每一行代碼
做好code review

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章