微服务与Java EE

原创 2017年08月29日 15:24:40

时至今日,基于微服务的架构已经随处可见了。我们见识到了Netflix与Amazon等创新者是如何通过微服务来取得业务上的成功。不过,对于那些使用Java EE服务器,编写传统系统的开发者来说应该何去何从呢?我们一直所做的都是错误的么?我们该如何让技术设计能够适应于未来?

单体架构

首先,我们来看一下这些传统系统,或者说是单体应用。虽然单体这个词现在看起来颇有一种坏味道之感,但这确实是我们长久以来构建软件的方式。基本上,它指的是这样一个事实,即我们构建一个个应用来实现某些功能。单体指的就是Java EE或是一开始的Java 2 Enterprise Edition设计的目标。集中式应用可以进行伸缩与集群,但其设计却不一定具有弹性。在大多数时候,其失败场景都要依赖于底层基础设施与运维。


传统上,Java EE应用遵循着一些核心模式,并且会分成3个主要的层次:展现、业务与集成。展现层会被打包到Web Application Archives(WARs)中,业务与集成逻辑则会被划分到单独的Java Archives(JARs)中。他们会被打包作为一个部署单元,即所谓的Enterprise Archive(EAR)。


围绕着Java EE的技术与最佳实践足以构建出设计良好的单体应用。不过,大多数企业级项目都不太关注架构。这也说明了为何有时设计良好的意大利面条是项目依赖与内部结构可视化的最佳方式。当这发生时,我们很快就会体会到一些严重的缺陷。由于一切都是耦合并且集成到一起的,因此即便进行一些非常小的变更也需要大量的工作(有时还需要重构),然后才能将修改过的部分放到产品中;同时,我们还需要从始至终非常小心地对应用进行测试。整个应用不仅仅只是一些程序化的构件:它还包含了很多部署描述符以及服务端配置文件,此外还有第三方环境的属性等。


开发这些企业项目需要多个团队联手,需要很多人从更高的视角来审查整个项目。业务组件与领域大多数都是由既有的数据库设计或是业务对象定义所驱动的。


变更的高风险与将新配置引入到生产中的复杂性会导致发布频率变得越来越低。新的发布可能一年才有那么几次。甚至团队结构都会受到单体软件架构的严重影响。长久的测试周期就是最直观的证据。



微服务

时代在不断发展,下一代系统架构与设计在几年前出现了。随着集中式集成组件日益增长的复杂性以及应用之间连接的成本越来越高,人们开始寻求更加轻量级、更加富有弹性的解决方案,逐步开始放弃大型、重量级基础设施与设计。与之相伴的是IT部门开始重新审视应用服务器以及冗长的协议和接口技术。对于那些基于SOA与ESB的项目来说,其服务实现回归到了更加敏捷的构件与服务中来。相对于智能路由与转换来说,微服务使用了简单路由,并且将逻辑封装到了端点本身当中。


微服务是围绕单业务目标而展开的。虽然企业系统的设置让人感到非常烦恼,但对于微服务来说,最有效的运行时却并不一定是功能完善的应用服务器。它可能只是个Servlet引擎,JVM已经足以作为一个执行环境了。


运行时千变万化,编程语言的选择也是数量庞大的,因此这种开发模式很可能会成为另一种运维梦魇。甚至连开发者都可能会在定义微服务以及如何将这种设计应用到既有应用中迷失方向。微服务的设计目标是要形成小型、无状态、独立且自包含的应用。在理想情况下,可以将其部署到任何地方,因为部署本身已经包含了所有必要的组件。


微服务要足够小。不过,“小型”的定义是很主观的。可以使用一些估算方法如代码行数、功能点、用例等。不过一般来说,“小型”与尺寸之间并没有什么必然的联系。在Building Microservices一书中,作者Sam Newman就微服务尺寸的定义给出了一些技术:


  • 足够小,可以由一个小型的敏捷开发团队所拥有

  • 可以在一两个敏捷Sprint(一般来说是2到4周)中完成重写

  • 其复杂度不需要对服务做进一步拆分


无状态应用在处理每个请求时只会使用请求所包含的信息。微服务必须要是无状态的,在处理请求时无需记住与外部系统之前通信的信息。微服务必须要能独立处理请求,它可以与生态系统当中的其他微服务协作来进行处理。比如说,在与其他微服务交互后生成报表的微服务就是个相互依赖的系统。在这种场景中,只向报表微服务提供必要数据的微服务可能是个独立服务。全栈应用本身是可以部署的。它拥有自己的服务器、网络、托管环境。业务逻辑、数据模型与服务接口(API / UI)必须是整个系统的一部分。微服务必须是个全栈应用。


创新与持续不断的改进是企业与企业级项目背后的助推器。如果没有创新,那些过时与昂贵的基础设施组件可能要比在他们上面运行的软件的生命周期还要长。老旧的中间件可能会超期服役,结果是只有少数供应商才知道如何开发它。落后于最新标准的平台栈可能会引入临时应急的解决方案,最终则会产生技术债务。将项目快速迁移到微服务的就是那些开源项目了。


Netflix OSS、Spring、Camel、Fabric8等都是很好的例子。借助于当下的PaaS,我们可以更加轻松地操纵多语言构成的全栈应用,而PasS一般来说也是由诸如Docker和Kubernetes等开源项目所维护的。在这个快节奏的时代中,从开发到上线以及修复Bug的时间被大大缩短了。几乎没有多少企业还能够容忍几个月的产品周期,他们需要软件为业务创造更多的价值。对于那些完全由软件驱动的公司如Uber、NetFlix、Amazon等来说更是如此。我们需要针对灵活性与弹性来构建系统,而不仅仅是效率和健壮性。Java EE并不会消亡,它会得到补充和完善。

版权声明:本文为博主原创文章,未经博主允许不得转载。

微服务与Java EE

本文来源于我在InfoQ中文站翻译的文章,原文地址是:http://www.infoq.com/cn/news/2016/01/microservices-and-java-ee时至今日,基于微服务的...
  • ricohzhanglong
  • ricohzhanglong
  • 2016年01月09日 01:04
  • 2527

微服务:Java EE的掘墓人

在Java问世之初,包括IBM、BEA、Oracle在内的一些巨头公司看到了Java作为一门杰出的Web编程语言可能给他们带来的巨大商机。那么如何通过一门编程语言来赚钱呢?答案就是使用这门语言构建复杂...
  • dica54dica
  • dica54dica
  • 2016年11月28日 09:49
  • 815

【Java EE (Struts2 + Spring + Hibernate)开发】: Struts2(一)基本用法(待续)

【Java EE (Struts2 + Spring + Hibernate)开发】系列之 Struts2(一)基本用法 本文地址:http://blog.csdn.net/shanglianlm/a...
  • shanglianlm
  • shanglianlm
  • 2015年11月22日 09:48
  • 944

java学习:基于Java构建微服务

基于Java构建微服务
  • javaniuniu
  • javaniuniu
  • 2016年06月05日 09:47
  • 1791

在 Java 中创建微服务

创建由微服务组成的应用程序的前景给所有语言都带来了一些疑问:微服务应该有多大? 对于传统的集中化治理,做一件事的专注服务的概念有何意义? 微服务会如何处理传统的数据建模方式? 本章将重点介绍如何识别和...
  • u010039929
  • u010039929
  • 2017年04月13日 10:54
  • 1941

如何快速构建基于java的微服务

推荐一下Java的spring-boot框架,其他语言肯定也有大神已经给出了可以快速搭建系统的方案,自己动手丰衣足食啊。闲话不多说,直接上代码:https://github.com/chxfantas...
  • u014070372
  • u014070372
  • 2016年12月01日 01:01
  • 1090

基于Java构建微服务 -- 初步认识

Container-less的微服务是将应用程序以及所有的依赖库打包到单个的JAR文件中。Container-less方法使得所谓的单一JAR部署成为可能(也称作“fat JAR”部署),这意味着,应...
  • xuanfengling
  • xuanfengling
  • 2016年06月13日 11:25
  • 5430

关于微服务和 Java 需要知道的 5 件事

Java 是一种历史悠久的语言,一些人会问它在微服务环境中是否有用。这篇文章将给出 Java 对现代应用程序(包括微服务)仍有很大价值的一些理由。 以下是您应该知道的关于微服务和 Java 的 5 件...
  • mulangren1988
  • mulangren1988
  • 2017年02月06日 11:33
  • 2736

JAVA和微服务

微服务是一种架构,其中的大型、复杂的软件应用程序由一个或多个更小的服务组成。每个微服务仅负责完成一项代表一种小业务能力的任务。这些微服务可使用任何编程语言开发。微服务是一种架构,其中的大型、复杂的软件...
  • u010039929
  • u010039929
  • 2017年04月13日 09:32
  • 942

如何使用Java构建微服务

三种方案!使用Java构建微服务!
  • sisiy2015
  • sisiy2015
  • 2015年11月18日 12:32
  • 2824
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:微服务与Java EE
举报原因:
原因补充:

(最多只允许输入30个字)