某日中午,收到告警,有一筆訂單下單失敗了。趕緊去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