用Spring Web Flow和Terracotta搭建Web应用

什么是Spring Web Flow?web

Spring Web Flow是Spring Framework中的web应用组件,它提供了一种编写有状态和基于会话的web应用的简便手段。Spring Web Flow 使得逻辑流程成为web应用中的一等公民,它能让你定义为自包含模块,以独立于应用的其它部分来配置和重用。它不依赖于框架从而可以方便的与可选的web应用框架一同使用,好比Spring MVC、Struts或者JSF等。spring

页面流转使用一种领域定义语言(DSL)来配置,这个语言专门开发用来定义和组合页面流转。目前的实现方式是XML和Java.编程

Spring Web Flow引入了能知足多种用户案例和需求的几种有状态数据域:request、flash、flow和conversation,这给你开发有状态web应用提供了很大的灵活性和能力。浏览器

这里是1.0 release中最有趣特性的快速概要:session

在一个地方而不是把逻辑分散在不少地方来定义应用任务的全部控制逻辑,好比一个搜索流程。app

把简单的流转组合在一块儿来建立富控制模块。框架

使用天然和面向对象的线性编程模型,而不是冗长的的if/else块来定义严格的用户导航规则。分布式

但流转结束或过时时自动清除你在流转执行中分配的内存。性能

在使用你选择的基础web框架的Servlet环境中Deploy一个可执行的流转。测试

改变web框架(好比Struts、Spring MVC、JSF及其它)而不用修改流转定义。

和环境一块儿改变而不须要修改你的流转定义, 好比从JUnit测试到Portlet。

开发时在不重启容器的状况下不断完善你的应用导航规则。

自动正确响应浏览器按钮(后退、前进、刷新)而不须要定制编程。

在4个受管理域中存储任务数据:request、flash、flow、和、conversation等,每一个都有本身的独特语义。

脱离容器单独测试流转。能在部署前确保应用控制逻辑能正常运做。

使用Spring IDE 2.0进行可视化编辑你的流转导航逻辑图

什么是Terracotta for Spring?

Terracotta for Spring是基于spring应用的运行时,它为Spring 应用提供了透明的高性能集群支持,对应用代码和部署及配置流程影响都很小。它经过在应用下面的堆级别进行集群而不是直接集群应用。 这让开发者可以开发与无状态方式不一样的单节点有状态Spring应用。这使得在须要扩展的应用开始设计时不考虑集群。而在应用须要扩展或者要保证搞可用性和故障恢复时,他们只须要在Terracotta 配置文件中定义哪些Spring应用上下文中的beans须要进行集群。Terracotta for Spring 使得应用可以被自动和透明的集群,还保证在集群间的语义和单节点同样。 对于Spring Web Flow来讲,这实际上更简单。用户为了得到web应用的状态和持续仓库的集群能力, 只须要在Terracotta配置文件中把特定的web应用声明为启用“session-support”。(详细内容见下面的章节“声明式配置”)

从宏观上看,Terracotta for Spring提供了:

HTTP session状态的集群。保证Spring Web Flow中的用户状态和扩展仓库或放入HTTP session的其它状态的高可用性和故障恢复能力。

Spring bean的集群。Springbean的生命周期语义和域在集群间被保存,它们在“逻辑”上相同的ApplicationContext中。目前能被集群的bean类型是singleton和session scoped. 用户能够声明式配置哪一个application contexts中的哪一个bean须要被集群。

透明集群POJO。 不须要修改已有的代码,甚至不须要源代码。应用基于不多的声明式XML 配置文件,在载入期透明的生效。Terracotta for Spring不须要实现Serializable, Externalizable或其它接口的类。能这样实现的缘由它并无使用序列化,而只是将实际的差量和已经改变了的数据传输给当前须要的节点 (lazily)。

虚拟内存管理。它也提供分布式垃圾收集和虚拟堆功能。好比,因为物理内存在须要时被换入换出,它能在一个4G RAM的机器上运行须要200G堆的Web应用。 这也意味着你不须要关心Spring Web Flow 会话数据的大小是否超过了物理堆大小。

相关文章
相关标签/搜索