• Spring Batch指南
  • Spring Batch指南
  • Spring Batch指南
  • Spring Batch指南
  • Spring Batch指南
  • Spring Batch指南
  • Spring Batch指南
  • Spring Batch指南
  • Spring Batch指南
21年品牌 40万+商家 超1.5亿件商品

Spring Batch指南

正版保障 假一赔十 可开发票

55.12 5.6折 98 全新

库存9件

广东广州
认证卖家担保交易快速发货售后保障

作者[美]迈克尔·T.米内拉(Michael T. Minella) 著;张坤,张渊 译

出版社清华大学出版社

ISBN9787302567721

出版时间2021-01

装帧平装

开本16开

定价98元

货号29192573

上书时间2024-10-27

兴文书店

三年老店
已实名 已认证 进店 收藏店铺

   商品详情   

品相描述:全新
商品描述
前言

Spring Batch是我深度参与的个开源项目。在我的记忆中,有两件事拖延了Spring Batch 1.0的发布:一是确保服务质量(Quality of Service,QoS)特性在实际工作中发挥作用;二是在API的设计上需要投入大量的精力。无论如何,错误是不可避免的,但我认为,至少可以说我们尽了努力,让生活有了一个良好的开端。
如果回顾一下Spring Batch的发展历程,你就会发现它起源于批处理领域,并且诞生于世界各地的许多企业长时间不断重复发明的过程之中。我次看到这些代码是在2006年,当时是Rob Harrop在伦敦一家银行做咨询工作时写的一个很小的原型。在我们将Spring Batch的一些有用特性分离出来,以便在其他项目中共享之后,这些部分终在Spring Retry中完成。Spring Batch剩下的大部分,以及Spring Batch面向状态机的世界观,都来自与埃森哲的合作。从那时起,有太多的贡献者加入,在此无法一一列出,但值得特别提及的是Lucas Ward,他是Spring Batch在早期的另一位家长和看护者。我还记得,Robert Kasanicky和Dan Garrette为Spring Batch 1.0在2008年的成功发布做出过巨大贡献。
以上贡献者也为Spring Batch 2.0在2010年的成功发布发挥了重要作用,我们在Spring Batch 2.0中引入了chunk的概念以及一些特性,以支持分布式处理、并行处理和Java 5的新语言特性。chunk(“块”)是可以一起处理的一组数据项,这为提高效率和可伸缩性提供了可能。Spring Batch 2.0在很长一段时间里代表的技术水平,并且在JSR-352规范启动时,成为其中的一部分。来自埃森哲的Wayne Lund在Spring Batch项目的早期就已加入其中,他也是JSR-352专家组的一员,现在是Pivotal的平台架构师。
那时候,Michael Minella也是JSR-352专家组的成员,他在现实生活中大量地使用Spring Batch并撰写了一本书。当他在2012年加入Spring团队时,Spring正好开始Spring Batch 3.0的准备和发布工作。在Spring Batch 3.0中,我们次看到了@EnableBatchProcessing注解,并且将重心从XML配置转到使用Java进行配置。Michael很快就以项目负责人的角色接管了这个项目,领导Spring Batch的3.x系列版本一直到4.0版本。在4.0版本中,Java 8成为基线,并且添加了一些新的流畅风格(fluent-style)的配置构建器。与Spring Cloud Data Flow的连接以及分布式处理的工业化也在这一时期发生。在2018年年初,Mahmoud Ben Hassine作为新的项目联合负责人加入进来,他一直在帮助Michael推动Spring Batch,并仔细听取了许多用户的反馈。
所以,在《Spring Batch权威指南》写作期间,Spring Batch已经发展了十年,期间也不断有优秀的贡献者加入进来。在未来几年里,Spring Batch肯定还有很多事情要做,因为批处理似乎永远不会消失。这确实很有意思。
Dave Syer,Spring Batch项目创始人
2019年于伦敦



导语摘要

主要内容: * 探索Spring Batch 4中的新特性。 * 使用Spring Batch项目在云环境中完成有限的批处理任务。 * 通过一些示例,理解*的基于Java和Spring Boot的配置技术 * 掌握复杂场景和云环境中的批处理 * 开发能够运行在现代平台上的批处理应用 * 除了Spring Batch,使用Spring Portfolio的其他部分开发关键任务型批处理应用



作者简介

Michael T. Minella是一位软件工程师、作家和演说家,拥有超过18年的专业经验。Michael是Pivotal的软件工程主管,领导了Spring Batch和Spring Cloud Task项目,他也是JSR-352(Java Batch)的专家组成员。另外,他还是一名Java Champion和JavaOne Rockstar,曾在许多不同的Java国际会议上发表演讲。
在日常工作外,Michael还在播客OffHeap上扮演“脾气暴躁的人”。他个人对信息安全话题(InfoSec)也很感兴趣。Michael的爱好包括摄影和木工,他和爱人Erica、孩子Addison生活在一起。



目录

第1章  批处理和Spring   1


1.1  批处理的历史   2


1.2  批处理面临的挑战   3


1.3  为什么使用Java进行批处理   4


1.4  Spring Batch的其他用途   5


1.5  Spring Batch框架   7


1.5.1  使用Spring定义作业   8


1.5.2  管理作业   9


1.5.3  本地和远程的并行化   9


1.5.4  标准化I/O   10


1.5.5  Spring Batch生态系统的其他部分   10


1.5.6  Spring的所有特性   10


1.6  如何阅读本书   11


1.7  本章小结   11


 


第2章  Spring Batch入门   13


2.1  批处理的架构   13


2.1.1  深入讨论作业和步骤   14


2.1.2  执行作业   15


2.1.3  并行化   16


2.1.4  文档   18


2.2  项目设置   19


2.2.1  获取Spring Batch   19


2.2.2  IntelliJ IDEA   21


2.3  “Hello,World!”示例程序   22


2.4  运行作业   25


2.5  本章小结   26


 


第3章  示例作业   27


3.1  了解敏捷开发   27


3.1.1  通过用户故事捕捉需求   28


3.1.2  使用测试驱动开发捕捉设计   29


3.1.3  使用版本控制系统   29


3.1.4  在真正的开发环境中工作   30


3.2  理解作业需求   30


3.3  设计批处理作业   34


3.3.1  作业描述   35


3.3.2  理解数据模型   36


3.4  本章小结   37


 


第4章  理解作业和步骤   39


4.1  作业介绍   39


4.2  配置作业   41


4.2.1  基本的作业配置   41


4.2.2  作业参数   43


4.2.3  使用作业监听器   55


4.2.4  执行上下文   58


4.2.5  操作ExecutionContext   58


4.3  使用步骤   62


4.3.1  Tasklet和基于块的处理   62


4.3.2  步骤的配置   63


4.3.3  理解其他类型的Tasklet   65


4.3.4  步骤流   80


4.4  本章小结   95


 


第5章  作业存储库和元数据   97


5.1  作业存储库是什么   97


5.1.1  使用关系数据库   97


5.1.2  使用内存存储库   101


5.2  配置批处理基础设施   101


5.2.1  BatchConfigurer接口   101


5.2.2  自定义JobRepository   102


5.2.3  自定义TransactionManager   103


5.2.4  自定义JobExplorer   104


5.2.5  自定义JobLauncher   105


5.2.6  配置数据库   106


5.3  使用元数据   106


5.4  本章小结   110


 


第6章  运行作业   111


6.1  使用Spring Boot启动作业   111


6.2  使用REST API启动作业   113


6.3  使用Quartz进行调度   118


6.4  停止作业   121


6.4.1  自然结束   121


6.4.2  以编程方式结束   122


6.4.3  错误处理   134


6.5  控制作业的重启   136


6.5.1  阻止作业再次执行   136


6.5.2  配置重启次数   137


6.5.3  重新运行一个完整的步骤   138


6.6  本章小结   139


 


第7章  ItemReader   141


7.1  ItemReader接口   141


7.2  文件输入   142


7.2.1  平面文件   142


7.2.2  XML文件   167


7.3  JSON   172


7.4  数据库输入   174


7.4.1  JDBC   174


7.4.2  Hibernate   180


7.4.3  JPA   184


7.4.4  存储过程   186


7.4.5  Spring Data   187


7.5  现有的服务   191


7.6  自定义输入   194


7.7  错误处理   198


7.7.1  跳过记录   199


7.7.2  把无效的记录记入日志   200


7.7.3  处理没有输入的情况   202


7.8  本章小结   203


 


第8章  ItemProcessor   205


8.1  ItemProcessor概述   205


8.2  使用Spring Batch提供的ItemProcessor   206


8.2.1  ValidatingItemProcessor   207


8.2.2  输入校验   207


8.2.3  ItemProcessorAdapter   213


8.2.4  ScriptItemProcessor   215


8.2.5  CompositeItemProcessor   216


8.3  编写自己的条目处理器   220


8.4  本章小结   222


 


第9章  ItemWriter   223


9.1  ItemWriter概述   224


9.2  基于文件的ItemWriter   225


9.2.1  FlatFileItemWriter   225


9.2.2  StaxEventItemWriter   235


9.3  基于数据库的ItemWriter   239


9.3.1  JdbcBatchItemWriter   239


9.3.2  HibernateItemWriter   244


9.3.3  JpaItemWriter   249


9.4  NoSQL ItemWriter   252


9.4.1  MongoDB   252


9.4.2  Noe4j   255


9.4.3  Pivotal Gemfire和Apache Geode   259


9.4.4  Repository抽象   263


9.5  输出到其他目标的ItemWriter   266


9.5.1  ItemWriterAdapter   266


9.5.2  PropertyExtractingDelegating-ItemWriter   268


9.5.3  JmsItemWriter   271


9.5.4  SimpleMailMessage-ItemWriter   275


9.6  复合的ItemWriter   280


9.6.1  MultiResource-ItemWriter   280


9.6.2  CompositeItemWriter   288


9.6.3  ClassifierComposite-ItemWriter   291


9.7  本章小结   294


 


第10章  示例应用   297


10.1  回顾银行对账单作业   297


10.2  配置新项目   298


10.3  导入客户数据   300


10.3.1  验证客户ID   306


10.3.2  写入客户更新   308


10.4  导入交易数据   311


10.4.1  读取交易   313


10.4.2  写入交易   314


10.5  计算当前余额   315


10.5.1  读取交易   316


10.5.2  更新账户余额   316


10.6  生成对账单   317


10.6.1  读取对账单数据   317


10.6.2  为对账单添加账户信息   320


10.6.3  写对账单   322


10.7  本章小结   326


 


第11章  伸缩和调优   327


11.1  分析批处理作业的性能   327


11.1.1  VisualVM之旅   328


11.1.2  分析Spring Batch应用的性能   331


11.2  伸缩作业   337


11.2.1  多线程步骤   337


11.2.2  并行步骤   339


11.2.3  组合使用AsyncItemProcessor和AsyncItemWriter   344


11.2.4  分区   346


11.2.5  远程分块   360


11.3  本章小结   365


 


第12章  云原生的批处理   367

—  没有更多了  —

以下为对购买帮助不大的评价

此功能需要访问孔网APP才能使用
暂时不用
打开孔网APP