成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

【方向盤】認為:開發者已無理由再用Java EE

開發 前端
Oracle的一頓猛如虎操作,讓開發者徹底失去了Java EE。Eclipse基金會則自立門戶,另起爐灶開啟Jakarta EE項目。

[[432394]]

正文

Oracle的一頓猛如虎操作,讓開發者徹底失去了Java EE。Eclipse基金會則自立門戶,另起爐灶開啟Jakarta EE項目。

對于Jakarta EE,從它的官網https://jakarta.ee能看到Eclipse基金會接手后共發布過三個版本:

  • Jakarta EE 8:2019年9月發布,交接過來后發布的首個版本。特征總結為:

①:內容完全同2017年8月發布的Java EE 8,無功能修改

②:對GAV坐標做了變化,如老的javax.servlet:javax.servlet-api:4.01變更為jakarta.servlet:jakarta.servlet-api:4.02。這是本次版本升級的主要目的,把GAV坐標先扭過來

③:命名空間依舊是javax,也就是說和Java EE 8是完全兼容的

  • Jakarta EE 9:2020年11月發布。這一次,是阻斷式升級。特征總結為:

①:GAV同Jakarta EE 8

②:再無javax命名空間,而是全新的jakarta命名空間。如:javax.servlet.Servlet改為jakarta.servlet.Servlet

③:所有EE技術大版本號均升1。如:Servet 4.01升為Servlet 5.0.0,用以告知開發者其向下不兼容性

  • Jakarta EE 9.1:2021年5月發布,增加JDK 11運行時支持。特征總結為:

①:不新增API,保持和Jakarta EE 9一樣

②:基線版本(最低編譯版本)依舊為JDK 8,但增加了JDK 11的運行環境

③:相關技術的版本號基本沒變化(只有少部分有小版本號+1情況)

總的來講,若想升級到Jakarta EE 9+版本,麻煩還是較大的。作為開發者的我們,該何去何從呢?本文就來分析下這給開發者帶來的轉變,佐證筆者為何得出結論:開發者已無理由再用Java EE。

升級到Jakarta EE有哪些轉變

當然,這里指的是升級到Jakarta EE 9+版本。由于它是阻斷式升級,盤點清楚哪些轉變將非常重要。

名稱

舊名稱:Java EE;新名稱:Jakarta EE。

除了對品牌有影響(畢竟是全新品牌嘛),對公司企業的影響不大,對開發者的影響也基本可忽略。

GAV坐標

這里以Maven的GAV坐標為例。

Java EE 8的GAV坐標:

  1. <dependency> 
  2.     <groupId>javax</groupId> 
  3.     <artifactId>javaee-api</artifactId> 
  4.     <version>8.0.1</version> 
  5. </dependency> 

 

Jakarta EE的GAV坐標:

  1. <dependency> 
  2.     <groupId>jakarta.platform</groupId> 
  3.     <artifactId>jakarta.jakartaee-api</artifactId> 
  4.     <version>8.0.0</version> 
  5. </dependency> 

 

解釋一下,也許你從未導入過甚至都沒見過這兩個API,它就是Java EE/Jakarta EE技術的集大成者:一個API包含所有EE技術,如servlet、ejb、el、validation等等。

對它陌生是因為絕大多數真實使用場景下,開發者并不會在一個project里面用全這些技術,而是按需導入獨立的API。

從截圖可以看到Jakarta EE 8的命名空間依舊是javax.*,但就像上面所描述的,若僅停在Jakarta EE 8的話,那便歲月靜好,一片和諧。但是,一旦升級到Jakarta EE 9+版本,景象就是這樣子的:

頂層命名空間改變!這就是接下來要說的內容。

命名空間

如果說????兩項轉變對企業和開發者的影響微乎其微,那么命名空間的不兼容的影響將是巨大的,甚至致命的。這無異于直接是釜底抽薪呀,頂層包名都不一樣了,所有模塊均受到徹徹底底的影響。

命名空間不兼容的具體表現

“自古”以來不缺由于不向下兼容最終作死了的技術,那作為標準的Java企業級技術這次迎來這么大的阻斷式升級,會有哪些具體表現呢?我們可以從下面這幾個角度窺探一下

所有服務器需要重新編譯

Java EE服務器類型眾多,由于命名空間的變化,所有的服務器均需要重新編譯、發版。如:

  • Eclipse的GlassFish:已適配。作為官方推薦的服務器,永遠最先適配
  • Red Hat的WildFly:已適配。截止稿前已有preview版本適配了新命名空間
  • Oracle的WebLogic:未適配。
  • IBM的WebSphere:未適配。

下圖列出了截止稿前,已對Jakarta EE 9新命名空間做了適配的服務器(若是Jakarta EE 8舊命名空間的話遠不止這么多哦,證明不少服務器廠商還沒行動呢):

Tips:你沒看錯,那個logo寫著中文字的是2002年就已創辦的中國公司:中創軟件商用中間件股份有限公司

Tomcat呢???嗯,Tomcat并非Java EE容器,而只是一個Servlet容器(Web容器)而已,所以不可能出現在這個列表里。但Apache Tomcat實現了四個 Jakarta EE規范:

  • Jakarta Servlet
  • Jakarta Standard Tag Library(JSTL)
  • Jakarta WebSocket
  • Jakarta Authentication

Apache Tomcat作為全球使用最廣泛(市占率超6成)的Web應用服務器,響應速度還是非常快的:

簡而言之,Tomcat從10.x版本開始全面擁抱jakarta.*命名空間,9.x及以下版本用于保持對javax.*命名空間的支持。

企業自身代碼修改

企業自己的project代碼需要將import javax.*替換為import jakarta.*,修改并不復雜,看起來很簡單實則不簡單。

中大型企業的項目、服務成百上千個,你還會覺得簡單嗎?

有些代碼承接著巨大的流量不能有半點閃失,雖說僅僅只是改了“不影響邏輯”的代碼,但這帶來的風險是企業必須付出更多的人力去規避的。

運維體系的修改

對于企業應用來講,一般會保持定期升級應用服務器的習慣。但由于存在新服務器不兼容老的應用的問題,所以部署系統可能就需要兩套,成倍的增加了運維的成本。另外,使用兩套服務器的話,是否要繳納雙倍的費用給服務提供商呢?這也是個問題~

以上列出企業若要升級到新版Jakarta EE需要面臨的至少三大難題,如若不能低成本的“破解”,你覺得還有升級的必要嗎?

什么叫不用Java EE?

作為一個Java開發者,肯定聽過Java EE這個名詞,但大多數人都會回答沒用過,我并不詫異,因為你大概率一直在使用Spring/Spring Boot。如果說用過Spring Boot就等于用過Java EE,我覺得太過于牽強了,就像總不能說每個開車的司機都用過內燃機、把玩過輪胎是一樣的道理。

如今在諸如Spring Boot這樣的框架包裝下,應用層已經找不到Java EE的蹤影了。所以“年輕的”面試者說沒用過Java EE并不會讓人覺得奇怪,畢竟在天朝互聯網企業中Spring已然成為實際的開發標準,且在持續侵蝕著Java EE的市占率,擁抱Spring Boot開發已是大勢所趨。

對于新一代開發者來講,Java EE已經是古董級技術,隨著Spring技術棧的普及,已經沒有什么理由再去使用Java EE/Jakarta EE技術,面向Spring編程會更高效。

估摸Oracle也是看形勢不對,索性就交出了Java EE順帶還混得個Eclipse基金會董事會席位,何樂而不為呢?但是,它不再讓繼續使用javax命名空間這行為實在太不講武德了,這件事引起了眾多開發者的反感。但,誰又惹得起呢,畢竟它乃是最擅長發律師函的Oracle呀!

Spring與Jakarta EE

Spring和Jakarta EE什么關系?

這個問題有點不太好回答,可以說它倆是競爭關系,也可以說Spring是基于Jakarta EE構建的;可以說Jakarta EE是企業級開發的 官方標準,也可以說Spring是企業級開發的實際標準。它倆濃情蜜意這么多年,早已不可分割,所以新的Jakarta EE要想得到更多的覆蓋率,很重要的一點就是得看看Spring對它的支持程度,方可快速普及。

2021年9月1日,一年一度的Spring One大會在線上舉行,Spring項目擁有者Pivotal公司發布了Spring Framework 6.0以及Spring Boot 3.0的RaodMap,最重磅的變化莫過于這兩個

基于Java 17。話外音:不再支持Java 8、Java 11

基于Jakarta EE 9。話外音:不再支持Java EE,不再支持javax命名空間

以Spring現在的影響力和能力,筆者覺得它完全有能力自立門戶,不帶Jakarta EE一起玩了。但是Spring一直秉持著不重復造輪子的理念,成長于社區反哺于社區,一起維護更好的生態環境,這不就是對Java開發者最大的“負責”么。

對于開發者而言,只需保持對Spring/Spring Boot的熱度即可,至于Jakarta EE的發展、迭代,就讓它“淪落為”汽車的發動機吧,無需關注。

Tips:即使不是Spring框架,普通開發者(如果你不甘只做普通開發者,就...)也不會回到需要關心Java EE/Jakarta EE的年代,所以dark不必擔心

總結

雖然Oracle不講武德的操作,一度讓開發者非常的失望和憤怒。但隨著Spring的官宣:“帶著”Jakarta EE繼續前行,Javaer重拾信心,穩步前行。

歷史的巨輪,浩浩蕩蕩的前進。有些是必然的趨勢,即使你現在還并不能接受,但這并不妨礙。Java 8再怎么堅挺,終究會迎來其生命的終點,這是不可阻擋的,比較人類需要進步,技術也是。

 

去Tomcat官網可以看到,它竟提供了應用進行自動代碼轉換以支持jakarta的工具。或許在不遠的將來我們可以看到各種奇yin巧技去搞兼容,又見那烏煙瘴氣的一幕。

 

責任編輯:武曉燕 來源: Java方向盤
相關推薦

2021-10-11 08:51:50

JavaMailJDBCJava

2010-12-21 11:36:58

職場

2023-03-10 14:55:28

2012-10-09 10:43:19

開發者開放源碼

2011-07-11 15:10:58

HTML 5

2012-05-02 09:42:19

開發者技術博客

2012-10-11 10:43:26

開發SQL

2021-10-25 08:16:20

Java JAX-RS Java 基礎

2013-10-21 15:55:36

Android開發者iOS

2021-10-08 06:50:32

版本歷史代碼

2010-01-26 09:23:18

Java EE 6

2010-09-28 13:36:06

AndroidiPhone

2011-07-31 19:44:43

程序員

2011-03-28 13:05:38

MeeGo諾基亞英特爾

2010-02-03 09:06:26

Java EE 6

2015-06-19 14:34:20

像素游戲

2015-10-27 09:36:31

Web開發者理由

2011-12-01 15:48:13

Web

2020-03-12 12:26:11

Docker容器開發者
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美亚洲视频 | 免费看国产一级特黄aaaa大片 | 亚州精品天堂中文字幕 | 亚洲一区二区在线免费观看 | 久久大香 | 91在线精品一区二区 | 日韩欧美精品一区 | 精品国产鲁一鲁一区二区张丽 | 日韩成人免费中文字幕 | 天天射美女 | 五十女人一级毛片 | 日本不卡视频 | 91精品久久久久久久久中文字幕 | 国产99久久精品一区二区永久免费 | h小视频 | 久久国产精品首页 | 久久91av| 日韩国产中文字幕 | 亚洲美乳中文字幕 | 亚洲一区二区三区在线视频 | 91偷拍精品一区二区三区 | 亚洲欧美激情国产综合久久久 | 日韩在线国产精品 | 91色视频在线观看 | 成人免费看电影 | 久久精品国产一区二区电影 | 亚洲性视频网站 | 免费在线性爱视频 | 亚洲高清av| 国产精品久久午夜夜伦鲁鲁 | 亚洲欧洲精品在线 | 四虎影院在线观看免费视频 | 国产精品成人久久久久 | 亚洲伊人精品酒店 | 国产一区二区三区精品久久久 | 91精品国产乱码久久久 | 成年免费大片黄在线观看一级 | 国产精品区二区三区日本 | 日韩免费高清视频 | 91精品国产综合久久福利软件 | 91国自产 |