这几天已经初步把YunEngine的整体架构定下来了,而且从今天开始,我将开始一个新的系列,名为“Java Development Without Spring”。为什么起这个名字呢?因为经过一段时间的思索,发现在云计算时代,像过去类似Spring这样有一定复杂性的Java框架都已经不适用了,而是强调简单开发和快速部署,并且将类似扩展和维护这样的复杂问题都抛给云平台来负责。本系列将通过多篇文章来对这个话题进行详细地展开,而本文作为本系列的第一篇,将重点专注于在云时代的Java应用。
首先,先总结一下普通Java应用的特点。对于大多数或者80%的Java应用而言,其本质就是一个提供数据CRUD服务的Web应用,所涉及到功能莫过于Web和数据存储这两块。同时,由于现有的云计算平台在所支持的功能上还无法面面俱到,所以现阶段将会主要以更好地支持普通的Java应用为主,而对于那些有很多特定的需求的应用而言,有可能现在云平台还不是特别适合它们。
那么,在这个云计算的时代,Java应用会发生那些变化呢?将主要应该包括下面这三方面:
- 简单开发:在开发方面,将会主要以选择简单熟悉的类库和框架为主,这样不仅能降低整体学习的难度,而且还会便于整体的实现,避免在开发前还需要深入学习框架和类库的尴尬。
- 快速部署:除了能直接通过Eclipse来进行调试,而且还能通过点击就能直接部署并运行,避免过去需要繁琐地调试应用服务器的痛苦。
- 基于标准:因为如果能尽可能按照标准API来编写Java应用,不仅避免出现被云平台锁定的情况,而且还能让应用在云平台和本地的数据中心之间进行迁移。
本文结束,下文将聊聊Spring框架的不足,并提出一套更适合云时代的Java编程模式。