2020-03-08 補償任務(wù)死循環(huán)

背景

由于數(shù)據(jù)同步鏈路太長,偶爾出現(xiàn)數(shù)據(jù)不一致的bad case,為了解決該問題,添加了全量數(shù)據(jù)的補償任務(wù),即分批次掃描全表數(shù)據(jù),然后串行同步

現(xiàn)象

上游同學(xué)凌晨2點群里同步,某批id一天更新次數(shù)高達25w次,影響到了上游數(shù)據(jù)表性能

異常編碼
import java.util.ArrayList;
import java.util.List;

public class Task {
    void sync() {
        while (true) {
            Long offset = 0L;
            try {
                List<Shop> res = ShopDao.get(offset, 20L);/*每次查20條*/
                for (Shop shop : res) {
                    try {
                        del(shop);
                    } catch (ServiceException e) {
                        /*打印日志*/
                    }
                }
                offset = res.get(res.size()-1).id; /*id為數(shù)據(jù)表主鍵id*/
            }catch (Exception e){
                /* 打印日志*/
            }
        }
    }

    void del(Shop shop) throws ServiceException {
        throw new ServiceException();
    }


}

class ShopDao {
    static List<Shop> get(Long offset, Long limit) {
        /* "select * from shopTable where id>#{offset} limit #{limit} order by id";*/
        return new ArrayList<>();
    }
}

class Shop {
    Long id;
}

class ServiceException extends Exception {
}
異常原因

串行執(zhí)行批量任務(wù)時,執(zhí)行任務(wù)組只catch了ServiceException,但是在這個批次中,有一個店鋪拋出的異常并不是ServiceException,導(dǎo)致了查詢數(shù)據(jù)表的fromId每次都得不到更新,即進入死循環(huán)

解決

將每組任務(wù)的catch異常改為Exception

反思
  • 編寫代碼時注意細節(jié)
  • 使用while(count<n)替代while(true),n為大于任務(wù)數(shù)量的異常定值,在執(zhí)行完任務(wù)時,記錄n,如果n>數(shù)據(jù)表的數(shù)量,則說明代碼存在異常
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 小編費力收集:給你想要的面試集合 1.C++或Java中的異常處理機制的簡單原理和應(yīng)用。 當(dāng)JAVA程序違反了JA...
    八爺君閱讀 5,206評論 1 114
  • 1. file n. 文件;v. 保存文件2. command n. 命令指令3. use v. 使用用途4. p...
    喵嗚Yuri閱讀 828評論 0 4
  • 一.線程安全性 線程安全是建立在對于對象狀態(tài)訪問操作進行管理,特別是對共享的與可變的狀態(tài)的訪問 解釋下上面的話: ...
    黃大大吃不胖閱讀 960評論 0 3
  • 第01章 JAVA簡介第02章 基礎(chǔ)語法第02章 遞歸補充第03章 面向?qū)ο蟮?4章 異常處理第05章 數(shù)組第06...
    順毛閱讀 564評論 0 1
  • 不足的地方請大家多多指正,如有其它沒有想到的常問面試題請大家多多評論,一起成長,感謝!~ String可以被繼承嗎...
    啟示錄是真的閱讀 3,069評論 3 3

友情鏈接更多精彩內(nèi)容