从Java EE到Jakarta EE,企业版Java的发展历程(建议收藏)

✍前言

诞生于1985年的Java语言,早已年过三旬,甚至已经越过“35岁魔咒”,比很多同学的年龄大得多。正所谓三十年河东,三十年河西,有人说Java已廉颇老矣,基本结构过于老套不灵活,但显示情况是它“老而不死”依旧常年霸榜,是棵常青树。

深爱Java的同学知道,Java并不老(Python年纪更大)、开发效率并不低(马拉松型选手看中长远效率)、语法并不是啰嗦(这是严谨的表现,同时也拥抱了Stream流式、Function函数式编程来简化开发)。Java鼓励用严谨的方法、正确的方式来设置内容,这让Java程序员们对待代码更有全局性,更适合构建规模性的企业级项目。

另外,Java做到了哪怕最新版JDK能(几乎)100%兼容首个版本,这无不依靠于优秀的设计和规范的制定。2000年左右随着Java的高速发展,被大量用于企业应用的开发,所以迫切需要规范的解决方案。

正所谓一流企业定标准、二流企业做品牌、三流企业做产品,这个活Sun公司自然不会放过,它就是企业版Java,也叫Java EE(后改名为Jakarta EE)。Java EE是一系列技术标准的集合(只定标准,不提供实现),其中很多技术经历这么多年的发展已经很成熟、应用得很广泛了。但深入了解后会发现,Java EE很多技术都是起个大早,赶个晚集,否则也不会有Spring现在的绝对霸主地位。

点拨-Java EE

本文提纲

版本约定

Java EE:6、7、8

Jakarta EE:8、9、9.1

✍正文

上面说到,Java能够历久弥新得益于它是非常严谨的、注重编码规范、注重设计规范的编程语言。按照规范实施做到有据可循,实施过程又可反馈给规范,形成正反馈的周而复始,越来越完善。

本专栏将介绍Java EE/Jakarta EE相关的几十种技术,作为Java企业级开发的标准技术,很多技术应用非常广泛。本文作为第一篇,将从发展历程出发,先一起全方位地了解到它。

JDK发展简史

在讲述Java EE的发展历程之前,先简要回顾(普及)一下JDK的发展史,方便在时间上对应参照,毕竟开发者一般对JDK的版本会更熟、更敏感些。

诞生:1995年5月,Oak语言改名为Java,标志着Java的诞生,并且提出了著名的 Write Once,Run Anywhere 口号。下面用表格形式记录其发版时间轴

版本发布日期焦点说明

JDK 1.01996.01Java虚拟机、基础类库

JDK 1.11997.02规定了Jar文件格式,JDBC、JavaBeans、RMI等。开始支持内部类和反射

JDK 1.21998.12引入集合框架Collections、Map等。从此版本开始,分为3个版本:J2SE/J2EE/J2ME(注:1999.04著名的HotSpot虚拟机诞生,顺势推出了Java EE首个版本)

JDK 1.32000.05千禧年的第一个版本,对类库进行了优化

JDK 1.42002.02支持正则Pattern、NIO、JDBC 3.0、assert断言

JDK 52004.09JDK命名方式变化、自动拆装箱、泛型、枚举、可变参数、增强for循环、JUC并发包 等等非常多新特性

JDK 62006.12编译器注解处理器(lombok的原理)、J2xx改为Java XX

JDK 72009.02try-with-resources、NIO2(也叫AIO)、泛型推断

JDK 82014.03憋了5年的大招,果然经典。 Lambda表达式、函数式编程、Stream流式编程、方法引用、接口默认方法、彻底移除HotSpot的永久代

.........

JDK 112018.09Jigsaw模块化、增强类型推断、革命性的垃圾收集器ZGC

.........

JDK 172021.09...敬请期待

期间,关于Java/Sun公司有些大事记,记录一下

日期事件

1995.05Java语言诞生

1996.01JDK 1.0版本发布

1998.12JAVA2企业平台J2EE发布(和JDK 1.2一起)

2005.06JavaOne大会召开(Java诞生10周年),J2EE更名为Java EE, J2SE更名为Java SE,J2ME更名为Java ME

2009.04甲骨文Oracle以现金收购Sun微系统公司,交易价格74亿美元 (Sun公司市值顶峰时超2000亿美金。眼看他起高楼,眼看他宴宾客,眼看他楼塌了)。Sun公司最大的资产,便是Java。从此Java商标被Oracle收入囊中,才有了后来的Oracle PK Google大战

2017.08Oracle将Java EE(Java SE还自己保留)交给开源组织,Eclipse基金会接手。但Oracle不允许开源组织使用Java名号,所以Jakarta EE名称于2018.02.26应运而生

什么是Java EE?

作为一个(资深)的Java开发者,这似乎是一个很简单的问题。

Java是一种可以撰写跨平台应用软件的面向对象的程序设计语言。它分为三个版本:

Java SE(J2SE):标准版。基础中的基础,后面2个版本都依赖于它。当前最新版本是Java 17(LTS版本,将于2021年9月发布)

Java EE(J2EE):企业版。用于企业级大型应用开发,包含了Web、Security、Management等几十种标准技术

Java ME(J2ME):移动版。随着Android/iOS的流行,它已几乎销声匿迹

由于Java EE能够直接应用于企业级应用开发,解决实际问题,直接产生价值,因此也常说它价值更高。所以用谷歌百度一下“Java培训”关键字,基本都是培训Java EE的。

作为common sense,特别是Java程序员除了需对JDK的历史有所了解外,Java EE的发展历程也是有必要知道的,毕竟这是基础知识点,是聊天的谈资,是你的内功

Java EE发展史

J2EE(JavaEE)自1999年首次发布以来,已成为实现和部署可移植、多层企业应用程序的集成标准(它是标准,它是规范),现在了解下它的发展史,记录到如下表格(总成体系的Java EE 1.4版本开始)。

说明:该表格是YourBatman翻阅多处资料搜集整合,全网最全的一份,请收藏使用。转载请注明出处

版本发布日期焦点说明

J2EE 1.42003.12对Web服务更好支持。启用javax命名空间。Servlet 2.4、JSP 2.0、EJB 2.1等

Java EE 52006.05以Web为着力点继续优化。Servlet 2.5、JSP 2.1、EJB 3.0、注解支持等

Java EE 62009.12添加了大量新技术来简化开发,如:Servlet 3.0(异步处理)、Bean Validation、EJB 3.1、JSF 2.0、JPA 2.0、上下文和依赖注入(CDI)

Java EE 72013.06提高生产力满足企业需求和HTML5。Servlet 3.1、WebSocket 1.0、JSON 1.0、JMX 2.0、Batch 1.0

Java EE 82017.08增加了JSON绑定和安全相关。Servlet 4.0、Bean Validation 2.0、CDI 2.0、JPA 2.2

Jakarta EE入局2017.08Oracle将Java EE交给开源组织,Eclipse基金会接手(Apache基金会爆冷出局还是不想要?)。但Oracle不允许开源组织使用Java名号,所以Jakarta EE名称于2018.02.26应运而生

Jakarta EE 82019.09规范与Java EE 8完全相同。Maven的GAV变了:

javax.servlet:javax.servlet-api:4.0.1 ->jakarta.servlet:jakarta.servlet-api:4.0.2 ,但命名空间没变依旧还是javax.*,算是个小过度吧

Jakarta EE 92020.11没有加入新功能,Eclipse基金会的首个正式版本。命名空间从javax.* 迁移到 jakarta.* ,前者从此成为历史。所有模块大版本号+1,如 Servlet 4.0.2 -> Servlet 5 以表示其断层式升级

Jakarta EE 9.12021.06相较于9没有加入新API。主要提供对Java SE 11的运行支持

2017年随着Oracle把Java EE交给开源基金会,Java EE从此成为历史,接下来将由社区驱动的Jakarta EE取而代之。

虽然Java EE已成过去式,但它似乎代表着我们的程序青春,依然是沟通的主力。因此,在很长很长很长一段时间内,Java EE知名度依旧盖过Jakarta EE,沟通交流中使用它居多。

Tips:Java EE版本号和Java SE没有绝对联系。如即使到最新的Jakarta EE 9、9.1版本对JDK的最低要求是8,而非9

咱们程序员可能会吐槽Oracle为毛不让使用Java EE商标,这么搞太费劲了。但在Oracle眼中,可能,一切都是利益(Oracle号称是一个律师比工程师数量还多的高科技企业)

补充:什么是Eclipse基金会

2004年2月该非盈利组织的正式成立,由包括开发者、消费者和插件提供商在内的各独立团体组成的董事会,为Eclipse的长期发展负责,它就是Eclipse基金会。

该基金会最初只有19个开源项目,现在有300+个之多,我们比较熟悉的就有:

Java开发工具:功能强大的Java开发IDE Eclipse

众多Jakarta项目:Jakarta Annotations、Jakarta Bean Validation、Jakarta JSON Processing等等

Vert.X:一个面向现代web和企业的异步应用框架,一个可能会撼动Spring地位的全家桶框架

另外,可把Eclipse基金会和Apache基金会对照着看,程序员对后者理应更熟悉些。

什么是Jakarta EE

该名称的由来和两个大事记有关:

为了让Java EE更开放,Oracle决定为它寻找一个新东家(呵呵,我笑而不语)。2017年8月,Oracle将Java EE交给开源组织,Eclipse基金会接手(Apache爆冷出局还是不想要?)

Oracle拒绝让基金会继续使用Java名字,因此Eclipse做了一项名义调查,从Jakarta EE和Enterprise Profile两个名称中二选一,前者大比例胜出。所以在2018年3月份,Eclipse宣布正式将Java EE更名为Jakarta EE,并且确定了logo(如上图)。另外,跟着更名的还有一些和Java EE紧密相关的名词,如Glassfish -> Eclipse Glassfish;JCP -> EE.next;ODM(Oracle Development Management) -> PMC

总而言之:Jakarta EE你可认为它(的内容)就是Java EE,只是名字换了,老东家换了。之前由JCP来推动它的发展,以后将有开源社区推动。至于前景如何,咱们拭目以待

Jakarta EE发展史

Jakarta EE还很年轻,2017年8月从Oracle手中接棒过来算起,也不过4岁,谈不上什么发展史,是好是坏周期太短也不能早下定论。截止到目前,共发布了三个版本,内容几乎没有变化,只在命名空间、版本号方面稍有改变,记录如下:

版本发布日期焦点说明

Jakarta EE 82019.09规范与Java EE 8完全相同。Maven的GAV变了:

javax.servlet:javax.servlet-api:4.0.1 ->jakarta.servlet:jakarta.servlet-api:4.0.2 ,但命名空间没变依旧还是javax.*,算是个小过度吧

Jakarta EE 92020.11没有加入新功能,Eclipse基金会的首个正式版本。命名空间从javax.* 迁移到 jakarta.* ,前者从此成为历史。所有模块大版本号+1,如 Servlet 4.0.2 -> Servlet 5 以表示其断层式升级

Jakarta EE 9.12021.06相较于9没有加入新API。主要提供对Java SE 11的运行支持

一站式聚合API

如你所知,Java EE/Jakarta EE是几十种技术(规范)的几何,几乎每种技术都有其API(对应一个Jar),为了方便总揽全局,Java EE自6版起提供了一站式聚合API,导入一个就够了:

<dependency>

  <groupId>javax</groupId>

    <artifactId>javaee-api</artifactId>

    <version>6.0.0</version>

    <scope>provided</scope>

</dependency>

<!-- Jakarta命名空间版本 -->

<dependency>

    <groupId>jakarta.platform</groupId>

    <artifactId>jakarta.jakartaee-api</artifactId>

    <version>9.1.0</version>

    <scope>provided</scope>

</dependency>

效果如下:

特别注意:实际工作中不建议使用这种粗暴的、大而全的导入方案,而是应该按需导入精确把握,还classpath一片“干净”,并且也能做到心中有数,方可运筹帷幄。

有Java EE SDK吗?

既然Java SE有JDK,那么Java EE是否也有SDK呢?答案:有的。Oracle官网/Jakarta EE官网均提供了SDK供以下载:

https://www.oracle.com/java/technologies/javaee-8-sdk-downloads.html

只不过此SDK可能让你失望了,它不是传统的软件开发工具包,而更像是一个技术合集,并且和自家的Glassfish强绑定,包含有以下内容:

doc官方文档

几十种技术的使用samples(基于Maven管理、构建)

glassfish容器,强耦合

总的来讲,如若是抱着学一学的目的那么可以down下来玩玩,毕竟里面的samples示例、文档比较全。如若你是抱着使用的目的,那就不建议了,毕竟glassfish我们(国内)很少使用。

✍总结

30年弹指一挥间,Java EE在逐渐淡出Java开发者的视野,但中短期来看它依旧是我们绕不过的内容,经常能听到、看到、聊到。当在研究Spring等开源框架的时候,也经常会看到Java EE的影子。

本文介绍了Java EE的发展史,目的是对它有个笼统的认识。从Java EE到Jakarta EE,它能否重新焕发生命力我不知道,但留下来的不少东西依旧是目前的主流(如Servlet规范、JPA等等),具有非常高的学习价值,切莫轻视

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345

推荐阅读更多精彩内容