Spring生态简介
目录 概述
做Java开发的人一提起,首先在脑海中浮现出的就是“IoC”,“AOP”,“ MVC”,“ ”等等这些名词,甚至大有“无不Java”的感慨。
实际上,时至今日已不再是一个简单的编程框架了,从最初的“SSH框架”发展到今天,和都几乎快要从程序员视野中消失了,而却发展成了一个非常庞大且完整的生态。
所以说,除非特别指明是生态中的某个具体框架,否则提起“”应该指的是整个生态。
说句不夸张的话,Java程序员只要精通了,也就掌握了Java开发的精髓。
在整个生态中包含了许多应用在特定场景的具体框架,如:“ ”,“ ”,“ Boot”,“ Cloud”等等,其中“ ”框架是整个生态的核心基础,其他框架都需要依赖“ ”提供的基础功能,而且每个框架都有自己独立的代码仓库。
项目说明
生态下的项目分为3类:主要项目(Main ),社区项目( ),已经终止但是目前还保留的项目( in the Attic)。
最新的生态项目列表详见: 。
主要项目
目前,生态中包含22个主要活跃的项目。
1.
项目是整个生态的基础,包含了最核心的功能,如:IoC,AOP, MVC等,其他项目都需要依赖 。
另外,还需要注意的是 项目又包含多个子模块,如:-core,-beans,-,-aop,-web,-等等。实际上, 项目是一个模块化的架构,各模块之间又存在依赖关系。我们在Java Web后台项目中使用得最多的 MVC实际上就是模块-,它与其他模块的依赖关系如下所示:
显然,-模块依赖-,-aop和-web。
2. Boot
Boot是一个开发基于的脚手架项目,它默认集成了嵌入式,配置注解化,支持快速集成第三方开发组件(如),大大降低了使用的门槛,而且内置了许多可以直接用于生产环境的功能,是目前用于开发微服务架构项目的不二选择。
值得注意的是:许多人刚接触 Boot的人把它神话了,固然使用 Boot能快速开发一个健壮的、可直接运行的项目,但是它的核心和基础来源于 。对于重度依赖的开发人员,应该先去吃透 ,只要真正掌握了 中各个模块的实现原理,对于在实际开发中使用 Boot遇到的问题也就迎刃而解了。
3. Cloud
Cloud为开发基于微服务架构的软件系统提供了一整套工具集合,其中包含了开发各个微服务组件的具体项目,如: Cloud (配置中心), Cloud (服务注册中心), Cloud (服务调用监控), Cloud (服务网关)等等。
Cloud的基础是 Boot,基于 Boot可以大大简化开发各微服务组件的流程。
4. Cloud Data Flow
Cloud Data Flow用于构建在云环境或K8S中基于微服务的实时或批数据处理架构,具体来讲就是支持一系列需要进行数据处理的场景,如:ETL,数据导入/导出,事件流,预测分析等等。
5. Data
Data旨在提供一套基于编程模型的数据访问API,是一个数据访问框架集合,其中包含了多个具体的支持不同方式访问特定数据库类型的子模块,如: Data JDBC(使用JDBC方式访问关系型数据库), Data (访问数据库)等。
这个模块的功能类似于这样的专门的ORM框架,在实际开发中可以根据需求进行灵活选择。
6.
的目的是提供一个简单的模型,用于构建企业级应用集成解决方案。
7. Batch
Batch是一个轻量级的批处理框架,旨在开发对企业系统日常运营至关重要的强大批处理应用程序。
支持事务管理,提供了基于Web的管理接口。
8.
是用于实现认证和授权,以及访问控制的安全框架,在Java生态与之提供类似的功能还有一个框架: Shiro。
依赖于 ,也就是说如果要 ,那么应用架构也必须是基于 的,这大大限制了 的使用场景;反之,Shiro就没有这样限制,而且从项目架构上Shiro更加简洁。当然, 提供了非常丰富的安全控制的功能,在某些方面甚至比Shiro更加完善,与之对应的是掌握的 的复杂度比较大。因此,对于在应用中是否选择 需要根据实际需求来决定。
9.
如果Web应用基于框架(即:使用了 MVC)开发,那么可以直接使用 来开发满足约束的服务。
这里需要理解一个单词简写:“”。( as the of state)是REST架构风格中最复杂的约束,也是构建成熟REST服务的核心。它的重要性在于打破了客户端和服务器之间严格的契约,使得客户端可以更加智能和自适应,而 REST 服务本身的演化和更新也变得更加容易。
10. REST Docs
REST Docs是一个文档工具,用于为REST架构风格的Web服务自动生成相应的文档,这样可以解放开发者专门撰写API文档的工作。
11. AMQP
AMQP项目旨在将核心的概念应用于基于AMQP的消息传递解决方案的开发中,它提供了一个“模板”的抽象用于发送和接收消息。
12.
是对 MVC的扩展,旨在简化移动Web应用的开发。
可以检测出当前请求使用的设备是PC、还是手机或者是平板以及用户设备是安卓平台还是iOS平台,然后根据请求设备的不同,返回适合该设备的视图。
13. For
虽然官方的说法是 For 旨在简化原声应用的开发,但其实这个有点太过于牵强。
For 提供了2个对原生应用开发的支持:
(1)提供了一个REST客户端
(2)支持访问安全API时的认证
14. Web Flow
Web Flow主要应用于需要在Web页面上创建引导用户执行类似“下一步”这样的基于流程的应用场景,该框架构建于 MVC之上。
15. Web
Web 用于开发服务,类似的框架如: CXF, Axis2。
16. LDAP
LDAP是一个工具,用于为基于的应用程序使用LDAP( )协议。
17.
提供了管理用户信息的API和对应实现, 使得支持集群会话变得简单,而不依赖于特定于应用程序容器的解决方案。
简单来讲,传统的方案依赖于特定的容器(如:), 就是提供独立于特定容器的解决方案。
其实,针对容器,集群化也有一个开源方案:-redis--。
18. Shell
Shell用于开发基于命令行交互的应用。
19. FLO
FLO是一个类库,是 Cloud Data Flow中流构建器的基础。
20. Kafka
Kafka用于在项目中与Kafka交互。
21.
是一个为开发人员在项目中使用状态机的框架,帮助开发者简化状态机的开发过程,让状态机结构更加层次化。
22. IO
简单来说, IO 是一个对项目依赖进行统一版本管理的工具。本质就是一个pom文件,它记录了项目和其它第三方库对应的版本信息。
社区项目
社区项目目前只有2个: ROO, Scala。
1. ROO:这是一个开发工具包,旨在快速构建一个Java应用。
2. Scala:支持在Scala中使用框架。
保留项目
某些项目已经终止了,但是仍然保留着,不必赘述。
最后总结
是一个生态系统,提供许多有用的编程框架或工具集。
本文的目的不在于详细介绍生态的每一个项目,而是通过一个全面的整理,对生态有一个完整的认识,在实际中根据需要灵活选择对应的组件来使用即可。
可以明确的是,当下最为流行的项目是这4个: , , Boot, Cloud。
如下图所示,再次对生态做一个概括性总结。
如果本文对你有帮助,别忘记给我个3连 ,点赞,转发,评论,
咱们下期见!答案获取方式:已赞 已评 已关~