這篇文章給大家分享的是有關(guān)批處理框架Spring Batch有什么用的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。
創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括懷仁網(wǎng)站建設(shè)、懷仁網(wǎng)站制作、懷仁網(wǎng)頁制作以及懷仁網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,懷仁網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到懷仁省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
什么是批處理?
在現(xiàn)代企業(yè)應(yīng)用當(dāng)中,面對復(fù)雜的業(yè)務(wù)以及海量的數(shù)據(jù),除了通過龐雜的人機(jī)交互界面進(jìn)行各種處理外,還有一類工作,不需要人工干預(yù),只需要定期讀入大批量數(shù)據(jù),然后完成相應(yīng)業(yè)務(wù)處理并進(jìn)行歸檔。這類工作即為“批處理”
為什么使用Spring Batch
Spring Batch 作為 Spring 的子項(xiàng)目,是一款基于 Spring 的企業(yè)批處理框架。通過它可以構(gòu)建出健壯的企業(yè)批處理應(yīng)用。Spring Batch 不僅提供了統(tǒng)一的讀寫接口、豐富的任務(wù)處理方式、靈活的事務(wù)管理及并發(fā)處理,同時(shí)還支持日志、監(jiān)控、任務(wù)重啟與跳過等特性,大大簡化了批處理應(yīng)用開發(fā),將開發(fā)人員從復(fù)雜的任務(wù)配置管理過程中解放出來,使他們可以更多地去關(guān)注核心的業(yè)務(wù)處理過程。
另外我們還需要知道,Spring Batch 是一款批處理應(yīng)用框架,不是調(diào)度框架。它只關(guān)注批處理任務(wù)相關(guān)的問題,如事務(wù)、并發(fā)、監(jiān)控、執(zhí)行等,并不提供相應(yīng)的調(diào)度功能。因此,如果我們希望批處理任務(wù)定期執(zhí)行,可結(jié)合 Quartz 等成熟的調(diào)度框架實(shí)現(xiàn)。
Spring Batch的整體架構(gòu)
分三層:應(yīng)用層,核心層,基礎(chǔ)設(shè)施層。應(yīng)用層包括所有的batch任務(wù)和用戶開發(fā)的代碼。核心層包括在運(yùn)行期運(yùn)行一個(gè)任務(wù)所需要的類,例如:JobLauncher,Job和Step的實(shí)現(xiàn)。應(yīng)用和核心層都在基礎(chǔ)設(shè)施層之上,基礎(chǔ)設(shè)施層包括通用的讀寫器(readers and writers)以及如RetryTemplate等服務(wù)。
Step執(zhí)行過程
應(yīng)用場景
定期提交批處理任務(wù)
并發(fā)批處理:并行執(zhí)行任務(wù)
分階段,企業(yè)消息驅(qū)動處理
高并發(fā)批處理任務(wù)
失敗后手動或定時(shí)重啟
按順序處理任務(wù)依賴(使用工作流驅(qū)動的批處理插件)
局部處理:跳過記錄(例如在回滾時(shí))
完整的批處理事務(wù):因?yàn)榭赡苡行?shù)據(jù)量的批處理或存在存儲過程/腳本
感謝各位的閱讀!關(guān)于“批處理框架Spring Batch有什么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!