Slide 1

Slide 1 text

1 JJUG(⽇本Javaユーザー会) ナイトセミナー 2024年4⽉ Jakarta EE特集 Java EE/Jakarta EEの現状と将来 ―クラウドネイティブ時代にJava EEは対応できるのか︖― ⽇本IBM ⽥中 孝清 (Twitter @TTakakiyo) https://openliberty.io

Slide 2

Slide 2 text

2 ⾃⼰紹介 2 n ⽥中 孝清 n ⽇本アイ・ビー・エム株式会社 テクノロジー事業本部 Data AI and Automation 事業部 Application Modernization テクニカルセールス n WebSphere Application Serverなどの テクニカルセールスを20年以上担当 n Twitter(X) @TTakakiyo n https://www.linkedin.com/in/takakiyo/

Slide 3

Slide 3 text

3 3 Java EE / Jakarta EEとは Jakarta Enterprise Edition

Slide 4

Slide 4 text

4 Javaは「仕様」があって「実装」がある 仕様︓ “The Java® Virtual Machine Specification” 実装 実装 実装 HotSpot VM Sun/Oracleの実装をベースに BEA Sys.のJRockitの機能を追加し OSS化されたJVM実装 最も広く使われている IBMの実装をベースにした OSS JVM Oracleが新たに始めた OSS JVMプロジェクト 「仕様」があるから,Javaのプログラムは, どのVMのうえでも(基本的に)同じように動作する

Slide 5

Slide 5 text

5 Java SE(Java Standard Edition) 5 Java VM Reflection Math Logging Versioning Collections Management Preference API Ref Objects Instrumentation Regular Expression Concurrency Utility JNI Zip lang and utils Beans JMX Date and Time Security XML JAXP Input / Output Serialization Networking Internationalization Extension Mechanism Override Mechanism IDL JDBC JNDI RMI / RMI-IIOP Scripting JAR GUI toolkit /User Interface Tools & Tool APIs Java SE APIs Java SE Runtime Environment (JRE) Java SE Development Kit (JDK) Java の実⾏・開発環境の 基本をさだめた仕様群

Slide 6

Slide 6 text

6 Java SEを構成する仕様(例 Java SE 21) https://docs.oracle.com/en/java/javase/21/docs/specs/ n ⾔語仕様 – The Java Language Specification, Java SE 21 Edition n JVM(Java仮想マシン)仕様 – The Java Virtual Machine Specification, Java SE 21 Edition n 標準API仕様 – Java® Platform, Standard Edition & Java Development Kit Version 21 API Specification n 関連ツール – Java® Development Kit Version 21 Tool Specifications n その他 – JAR File Specification – Java AWT Native Interface Specification and Guide – Java Debug Wire Protocol – Java Native Interface (JNI) Specification – Java Object Serialization Specification – ・・・ 6

Slide 7

Slide 7 text

7 Jakarta EE / Java EE(Java Enterprise Edition)とは n エンタープライズ・ITシステムを Javaで構築するための追加APIの標準仕様群 7 Java SE Runtime RESTful Web Services Servlet Messaging Pages Batch JSON Binding Faces XML Web Services Enterprise Beans XML Binding JSON Processing Concurrency Security Authentication Jakarta EE APIs Authorization

Slide 8

Slide 8 text

8 Jakarta EEを構成する仕様の⼀部 n Web Container – Jakarta Servlet – Jakarta Pages(JSP) – Jakarta Faces(JSF) n Enterprise Beans Container – Jakarta Enterprise Beans(EJB) n 各種サービス – Jakarta Contexts and Dependency Injection(CDI) – Jakarta Persistence(JPA) – Jakarta Transaction(JTA) – Jakarta Messaging(JMS) – Jakarta Connector(JCA) – Jakarta RESTful Web Services(JAX-RS) – Jakarta XML Web Services(JAX-WS) – Jakarta Concurrency (Concurrency Utility for Java EE) 8 ( )内はJava EEでの名称

Slide 9

Slide 9 text

9 標準化された仕様の価値 n Java EE仕様にしたがって書かれたライブラリ・アプリケーションは, (原則として)どの実装でも同じように稼働する n 開発者も,学習したスキルをより⻑く普遍的に活⽤することができる n 特定のベンダーの買収や経営⽅針の変更によって,技術の動向が左右される危険が少ない 9 仕様︓ “Jakarta EE / Java EE Specification” 実装 実装 実装 実装 実装

Slide 10

Slide 10 text

10 Spring Framework/Spring Bootも内部で使⽤ n Spring Bootの成果物であるJARファイルは, 内部に格納されたEmbedded Tomcat(やJetty, Undertow)で, Jakarta EE/Java EEのServlet実⾏環境上で,実⾏されている n そのため,Spring Bootの成果物を他のJakarta EE実装で実⾏したり, Jakarta EEアプリケーションの中から Spring Frameworkの機能を使⽤することも可能 – Spring Bootの成果物をOpen Libertyのうえで実⾏すると, ピーク時のスループレットが倍増する 10 https://openliberty.io/blog/2022/10/17/memory-footprint-throughput-update.html

Slide 11

Slide 11 text

11 Java EEの歴史 n Java Community Process(JCP)で仕様策定がおこなわれてきた – Java EE 6までは,Sun Microsystems社が仕様策定を主導 – Java EE 7以降は,Sunを買収したOracle社が仕様策定を主導 11

Slide 12

Slide 12 text

12 Java EEからJakarta EEへの移⾏ n 様々な紆余曲折があり,エンタープライズJavaの仕様策定は, Oracle主導のJCPから,オープンなコミュニティであるEclipse Foundationへ移⾏された n Eclipse Foundation傘下で活動するJakarta EE Working Groupが, 各種のJakarta Projectで仕様策定を⾏う

Slide 13

Slide 13 text

13 Jakarta EEの組織 n 4段階のメンバーシップ – Strategic Member – Enterprise Member – Participant Member – Guest Member n 3つのCommittee – Marketing Committee – Specification Committee – Steering Committee 13 https://jakarta.ee/membership/members/

Slide 14

Slide 14 text

14 Jakarta EEプロジェクトの役割 n 仕様を策定する – ドキュメントならびにJavadoc – こちらから参照できる https://jakarta.ee/specifications/ n 実装が互換性があると認定されるのに必要なテストをおこなう TCK(Technology Compatibility Kit)を開発する – 実装ならびにドキュメント n 少なくとも⼀つの,TCKを通過した実装(Compatible Implementation) – Java EE時代はGlassFishだけだったが,Jakarta EEでは複数の実装が利⽤される 14

Slide 15

Slide 15 text

15 Jakarta EEプロジェクトのこれまで n 2019年9⽉ Jakarta EE 8.0 – Jakarta EE最初のバージョン – Eclipse Foundationでのコミュニティプロセスをまわすためのバージョン – 技術的には,Java EE 8.0と全く同じ – 仕様名の名前の付け⽅がバラバラだったものが,統⼀性のある名前に変更になった (変なアクロニム多過ぎ問題が改善) n 2020年11⽉ Jakarta EE 9.0 – 名前空間(パッケージ名)をjavaxからjakartaに変更 – いくつかの仕様の削除(旧JAX-RPC, JAX-R, Java EE Management, Java EE Deploymentなど) n 2021年5⽉ Jakarta EE 9.1 – Java SE 11仕様への対応 n 2022年9⽉ Jakarta EE 10 – Core Profileの新設 – 新しい機能やAPIの追加 n 2024年7⽉ Jakarta EE 11公開予定 15

Slide 16

Slide 16 text

16 Java EEからJakarta EEでの仕様名の変更(1) n Jakarta Pages︓JSP(Java Server Pages) n Jakarta Faces︓JSF(Java Server Faces) n Jakarta Persistence︓JPA(Java Persistence API) n Jakarta Messaging︓ JMS(Java Message Service) n Jakarta Connector︓JCA(Java Connector Architecture) n Jakarta Transaction︓JTA (Java Transaction API) n Jakarta Concurrency︓Concurrency Utility for Java EE n Jakarta Validation︓Bean Validation n Jakarta RESTful Web Services︓JAX-RS(Java API for RESTful Web Services) n Jakarta JSON Binding︓JSONB n Jakarta JSON Processing︓JSONP 16

Slide 17

Slide 17 text

17 Java EEからJakarta EEでの仕様名の変更(2) n Jakarta XML Web Services︓JAX-WS(Java API for XML-based Web Services) n Jakarta XML Binding︓JAXB(Java Architecture for XML Binding) n Jakarta Web Services Metadata︓JWS(Java Web Services Metadata) n Jakarta SOAP with Attachments︓SAAJ(SOAP with Attachments API for Java) n Jakarta Security︓Java EE Security API n Jakarta Authentication︓ JASPIC(Java Authentication Service Provider Interface for Containers) n Jakarta Authorization︓JACC(Java Authorization Contract for Containers) 17

Slide 18

Slide 18 text

18 Jakarta EE 10仕様の全体像とProfile Batch 2.1 Connectors 2.1 Messaging 3.1 Authorization 2.1 Activation 2.1 Mail 2.1 Enterprise Beans 4.0 RESTful Web Services 3.1 JSON Processing 2.1 JSON Binding 3.0 CDI Lite 4.0 Annotations 2.1 Interceptors 2.1 Dependency Injection 2.0 Server Pages 3.1 Expression Language 5.0 Standard Tag Libraries 3.0 Servlet 6.0 Faces 4.0 WebSocket 2.1 Enterprise Beans Lite 4.0 Managed Beans 2.0 CDI 4.0 Concurrency 3.0 Debugging Support 2.0 Authentication 3.0 Security 3.0 Persistence 3.1 Transactions 2.0 Bean Validation 3.0 Jakarta EE 10 Core Profile Jakarta EE 10 Web Profile Jakarta EE 10 Platform サブセット サブセット 新規 更新なし 更新 XML Web Services 4.0 XML Binding 3.0 SOAP w/Attachments 3.0 Enterprise Web Services 2.0 オプション

Slide 19

Slide 19 text

19 Web Profile n Java EE 6で導⼊された,Webアプリ⽤途に限定したJava EE / Jakarta EEのサブセット n Webアプリケーションで広く使われている技術に限定し,実装を公開しやすくするために設定 – が,Web Profileでも実装は⼤変で,最近ではTomEEがJakarta EE 9.1 Web Profileの認定を受けただけ・・・ 19 RESTful Web Services 3.1 JSON Processing 2.1 JSON Binding 3.0 CDI Lite 4.0 Annotations 2.1 Interceptors 2.1 Dependency Injection 2.0 Server Pages 3.1 Expression Language 5.0 Standard Tag Libraries 3.0 Servlet 6.0 Faces 4.0 WebSocket 2.1 Enterprise Beans Lite 4.0 Managed Beans 2.0 CDI 4.0 Concurrency 3.0 Debugging Support 2.0 Authentication 3.0 Security 3.0 Persistence 3.1 Transactions 2.0 Bean Validation 3.0 Jakarta EE 10 Core Profile Jakarta EE 10 Web Profile サブセット サブセット

Slide 20

Slide 20 text

20 Core Profile n MicroProfileは,複数のベンダーやコミュニティが共同で策定している, Javaでマイクロサービース・アーキテクチャーのアプリを実装するための仕様群 n Java EE/Jakarta EEアプリケーションの仕様の⼀部にくわえ REST呼び出しや,Kubernetes環境との連携などに関連した機能を追加で定義 n Jakarta EEで,MicroProfileと共通の部分をCore Profileとして定義 RESTful Web Services 3.1 JSON Processing 2.1 JSON Binding 3.0 CDI Lite 4.0 Annotations 2.1 Interceptors 2.1 Dependency Injection 2.0 Jakarta EE 10 Core Profile サブセット MicroProfile 6.0 Telemetry 1.0 Open API 3.1 Rest Client 3.0 Config 3.0 Fault Golerance 4.0 Metrics 5.0 JWT Authentication 2.1 Health 4.0

Slide 21

Slide 21 text

21 21 Jakarta EE 11 Next Jakarta EE Special Thanks: K. Kazumura

Slide 22

Slide 22 text

22 Jakarta EE 11 n Java SE 17が仕様の前提,TCKはJava SE 21でも動作するように実装予定 n 2024年1⽉から,Wave 1から8に分割して各仕様のFinalize作業を実⾏中 – Wave 1: Annotation, JSON Processing – Wave 2: Expression Language, Interceptors, Lang Model – Wave 3: Activation, Context and Dependency Injection – Wave 4: JSON Binding, Mail, SORP with Attachments, XML Binding – Wave 5: Authorization, Batch, Persistence, RESTful Web Services, Server Pages, Servlet, Validation, WebSocket, XML Web Services, Standard Tag Library – Wave 6: Authentication, Concurrency, Faces, Messaging – Wave 7: Security, Data – Wave 8: Platform, Web Profile, Core Profile n 2024年6〜7⽉に公開予定(現在は7⽉中旬を予定) n Compatible Implementation – Eclipse Glassfish – 他の実装を間に合わせるため,スケジュールを調整中 22

Slide 23

Slide 23 text

23 Jakarta EE 11の更新内容(現在の予定) n 新規仕様の追加 – Jakarta Data 1.0 n メジャー更新 – Annotation 2.0 → 3.0 – Authorization 2.1 → 3.0 – Expression Language 5.0 → 6.0 – RESTful Web Services 3.1 → 4.0 – Security 3.0 → 4.0 – Server Pages 3.1 → Pages 4.0 23 n マイナー更新 – Activation 2.1 → 2.1.3 – Authentication 3.0 → 3.1 – CDI 4.0 → 4.1 – Concurrency 3.0 → 3.1 – Faces 4.0 → 4.1 – Interceptors 2.1 → 2.2 – JSON Binding 3.0 → 3.0.1 – JSON Processing 2.1 → 2.1.3 – Mail 2.1 → 2.1.3 – Persistence 3.1 → 3.2 – Servlet 6.0 → 6.1 – Standard Tag Library 3.0 → 3.0.1 – Bean Validation 3.0 → Validation 3.1 – WebSocket 2.1 → 2.2 – XML Binding 4.0 → 4.0.2

Slide 24

Slide 24 text

24 Jakarta Data 1.0 リレーショナルデータベースなどにたいして, より簡単な操作⼿段を提供する n リポジトリ抽象化 – データアクセスのためのリポジトリインターフェースを定義し、具体的なデータベース操作を抽象化 – データベースアクセスを簡単にし、開発者がデータ操作に集中できるように n クエリの容易化 – メソッド名に基づくクエリ⽣成や、カスタマイズされたクエリの定義をサポート – 複雑なクエリも簡潔に記述できるように n ポータビリティと統合性 – 他のJakarta EE仕様と密接に統合され、アプリケーションの他の部分とシームレスに連携 – ⼀貫したアーキテクチャが保たれ、ポータビリティが向上 24

Slide 25

Slide 25 text

25 Jakarta Dataのコードの例 25 @Entity public class User { @Id public Long id; public String name; public String email; } import jakarta.data.repository.CrudRepository; public interface UserRepository extends CrudRepository { // 例えば、名前によるユーザー検索: List findByName(String name); } public class UserService { @Inject private UserRepository userRepository; public List findUsersByName(String name) { return userRepository.findByName(name); } } リポジトリを定義 サービスクラスに Injectして利⽤ 対象のエンティティを定義

Slide 26

Slide 26 text

26 同じようなコードをJakarta Persistenceで書くと・・・ 26 @Entity public class User { @Id public Long id; public String name; public String email; } public class UserService { @PersistenceContext private EntityManager entityManager; @Transactional public List findUsersByName(String name) { return entityManager .createQuery("SELECT u FROM User u WHERE u.name = :name", User.class) .setParameter("name", name) .getResultList(); // 名前に基づいてユーザーを検索する } } 対象のエンティティを定義 検索の疑似SQLを⾃分で記述する必要がある

Slide 27

Slide 27 text

27 いますぐJakarta Dataを試したい⽅は n Open Liberty Beta版でお試しいただけます。 – https://openliberty.io/blog/2023/12/19/24.0.0.1-beta.html 27

Slide 28

Slide 28 text

28 Jakarta RESTful Web Services 4.0 n JAX-RSの後継仕様 n Version 4.0での更新 – カンマ(,)で区切られたヘッダーを処理する機能を追加 – TCKに機能を追加 – ドキュメントの修正 – JAXBやManaged Beanへの依存を削除 28

Slide 29

Slide 29 text

29 Jakarta Pages 4.0 n JSP(Java Server Pages)の後継仕様 n Version 4.0での更新 – ErrorDataで新しい属性jakarta.servlet.error.query_stringの追加 – 3.1で⾮推奨になった機能の削除 29 機能の削除など破壊的な変更があると メジャー更新となっている マイナー更新より新機能が多いわけではない

Slide 30

Slide 30 text

30 Jakarta Validation 3.1 n 仕様名がJakarta Bean Validationから変更 n 新機能 – Recordのサポート 30

Slide 31

Slide 31 text

31 Jakarta Concurrency 3.1 n Concurrency Utilities for Java EEの後継仕様 n Version 3.1での更新 – Java 21 Virtual Threadの統合(Java 21以降で実⾏されたときにのみ利⽤される) – Java 11で追加されたjava.util.concurrent.FlowおよびReactive Streamのサポート – EJB,JNDI,リソース参照などへの依存を仕様から削除 – 注⼊において,古い@Resourceでなく,CDIの@Injectをメインにすることを明⽂化 – ドキュメントの修正 – TCKの問題の修正 31

Slide 32

Slide 32 text

32 Jakarta Servlet 6.1 n 新機能 – リダイレクト後にもステータスコードとレスポンスボディの制御を可能に – エラー画⾯から,Query⽂字列の参照が可能に – 新しく定義されたHTTPステータスコードへの対応 – ⽂字コードをStringではなくCharSetで指定するメソッドの追加 – ServletInputStreamとServetOutputStreamでByteBufferのサポートを追加 – 仕様の曖昧だった様々な部分を明確化 – SecurityManagerへの参照の削除 32

Slide 33

Slide 33 text

33 Jakarta Persistence 3.2 n JPA(Java Persistence API)の後継仕様 n 今回⼀番変更点が多い – Recordのサポート – JDBCの基本型とjava.time.Instant,java.time.Yearのマッピングをサポート – Persistence QLでunion, intersect, except, cast, left, right, replaceのサポートを追加 – Persistence QLの演算⼦に||を追加 – EntityResultのlockMode()のデフォルトをOPTIMISTICに – Query, TypedQuery, StoredProcedureQueryにgetSingleResultOrNull()を追加 – 仕様⽂章の曖昧だった点の明確化 – javadocの修正 – ⽇付に関わる型はjava.time APIを基本とし,Calender,Data, Time, Timestamp等は⾮推奨に – いくつかの機能を⾮推奨,削除を⽬的とした⾮推奨に などなど,ほか数⼗件の機能追加・修正 33

Slide 34

Slide 34 text

34 34 Jakarta EEへの移⾏ jakarta名前空間への対応

Slide 35

Slide 35 text

35 名前空間(パッケージ名)の変更 n javaxのパッケージ名は,Oracle社の保持する商標上の制限があるため, Jakarta EEプロジェクトで拡張することは許されなかった – Java EEから拡張していないJakarta EE 8での使⽤はできた n ⼀気に移⾏(ビッグバン)と 段階的な移⾏が検討されたが, 前者が選択された – Jakarta EE 9.0で,全仕様が jakarta名前空間に移⾏された n Java EEからJakarta EEへの移⾏には パッケージ名の変更が必要 35 import javax.annotation.Resource; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.sql.DataSource; import jakarta.annotation.Resource; import jakarta.servlet.ServletException; import jakarta.servlet.annotation.WebServlet; import jakarta.servlet.http.HttpServlet; import jakarta.servlet.http.HttpServletRequest; import jakarta.servlet.http.HttpServletResponse; import javax.sql.DataSource;

Slide 36

Slide 36 text

36 名前空間の移⾏に使えるツール(専⽤ツール) n Apache Tomcat migration tool for Jakarta EE – Apache Tomcat⽤に開発されている変換ツール(Apache License 2.0) – ソースコード,設定ファイルを変換するツール n Eclipse Transformer – Eclipse Foundationで開発されている変換ツール(EPL 2.0/Apache License 2.0) – ソースコード,設定ファイル,クラスファイルを変換するツール – コンパイル済みのバイトコードも変換できる – 使⽤例︓ 36 java -jar org.eclipse.transformer.cli-0.5.0.jar ¥ ~/opt/struts-1.3.10/lib/struts-core-1.3.10.jar ¥ ~/opt/struts-1.3.10/lib.tmp/struts-core-1.3.10.jar -v

Slide 37

Slide 37 text

37 名前空間の移⾏に使える各種ツール n OpenRewrite – Moderneが開発しているソースコードの⾃動リファクタリングを⾏うためのOSS (Apache License 2.0) – Javaのソースコード,構成ファイル等を「レシピ」にしたがって⾃動修正する – Java EEからJakarta EEへ移⾏するレシピも公開されている – レシピは⾃作することも容易で,⾃動変換に失敗した場合も,⾃作レシピで対応することが可能 n The Konveyor Tool Kit – Red Hatが開発している,既存のアプリケーションをクラウドネイティブな アーキテクチャに移⾏するための⼀連のツールキット(Apache License 2.0) – これに含まれているMigration Toolkit for Applications(旧名MTA/WindUp)が, Javaアプリケーションのソースコードを分析し、移⾏に関連する問題を特定し、 対応策を提供するためのレポートを⽣成 n 各種IDE上の移⾏ツール – IntelliJ IDEAのマイグーレション・ツールなどでも移⾏は可能 37

Slide 38

Slide 38 text

38 名前空間の移⾏に使えないツール n IBM Transformation Advisor – 従来型のWebSphereや,WebLogic/JBoss/Tomcatなどで稼働している Java EEアプリケーションを,WebSphere Liberty / Open Libertyに移⾏するためのツール – コンパイル済みのアプリケーションのバイナリを分析し,移⾏に必要な修正点などをレポート – Liberty向けのアプリケーションプロジェクトやLibertyの構成ファイル, コンテナ移⾏に必要なファイルなどを⾃動⽣成 – Libertyでは,Java EEアプリケーションも実⾏可能なので(詳しくは後述) 名前空間の変換機能は実装されていない n Oracle WebLogic Kubernetes Toolkit – Oracle WebLogic ServerをKubernetes環境にデプロイし,管理するためのツール – WebLogicドメインの管理,モニタリング,スケーリングを Kubernetesエコシステム内で実現することをサポート – WebLogicでは,Jakarta EEのアプリケーションは稼働しないので 名前空間の変更機能は実装されていない 38

Slide 39

Slide 39 text

39 アプリから使⽤されているライブラリの名前空間移⾏ 1. jakarta名前空間に移⾏されたバージョンを使⽤する – ライブラリの提供元からjakarta名前空間に移⾏されたバージョンが提供されていれば, 可能な限りそれを利⽤することが望ましい – ライブラリによっては,バージョンアップで⼤きな変更負荷がかかる可能性がある 2. javax名前空間のライブラリを変換して使⽤する – jakarta名前空間に対応したライブラリが提供されていない場合, ⾃⾝でソースコードあるいはバイトコードを変換して利⽤する – 変換後にトラブルが起こったときの対応が極めて困難 3. javax名前空間のままで利⽤する – 今後もjavax名前空間が利⽤可能な実⾏環境へ移⾏する – Open Liberty / WebSphere Libertyであれば,javax名前空間のままでも クラウドネイティブ化などのモダナイズが可能 39

Slide 40

Slide 40 text

40 40 Jakarta EEについて アンケートのお願い Jakarta EE 開発者アンケート 2024

Slide 41

Slide 41 text

41 Jakarta EE 開発者アンケート 2024 41 n 現在Jakarta EE Working Groupでは, 開発者向けのアンケートを実施しています n ⽇本語で回答できるページが⽤意されています n ⽇本の開発者の声を届けるため 是⾮みなさまの回答をお願いします https://www.surveymonkey.com/r/WZKXNQR?lang=ja

Slide 42

Slide 42 text

42 42 エンタープライズJavaの 最近の動向 各種仕様群や各種実装について

Slide 43

Slide 43 text

43 エンタープライズJava技術の業界動向 43 Jakarta EE Java EE J2EE 2024 2006 2019 MicroProfile ミドルウェアによる クラスタリング 仮想マシン モノリシック オンプレミス コンテナ Kubernetes オープンソース マイクロサービス クラウドネイティブ Serverless DevOps Spring Framework . Spring Boot OpenShift インフラによる クラスタリング

Slide 44

Slide 44 text

44 OSSの実装︓Tomcat nVersion 9.x – Java EE 8 / Jakarta EE 8の⼀部であるServlet 4.0 / JSP 2.3等に対応 nVersion 10.x – Jakarta EE 9の⼀部であるServlet 5.0 / Pages 3.0等に対応 nVersion 11.x – Jakarta EE 10の⼀部であるServlet 6.0 / Pages 3.1等に対応 nSpring Boot 2.x – 内部でTomcat 9.xを使⽤ nSpring Boot 3.x – 内部でTomcat 11.xを使⽤ 44

Slide 45

Slide 45 text

45 OSSの実装︓Eclipse Glassfish Eclipse Foundation⾃⾝で開発されている 仕様公開時に同時に公開されるCompatible Implementation FujitsuのInterstageなどの実装にも使⽤される nVersion 5.1.x – Java EE 8 / Jakarta EE 8対応 nVersion 6.0.x / 6.1.x – Jakarta EE 9/9.1対応 nVersion 7.0.x – Jakarta EE 10対応 nVersion 8.0.x – Jakarta EE 11対応予定 45

Slide 46

Slide 46 text

46 OSSの実装︓WildFly Red Hatの開発するOSSでJBoss EAPの実装に使⽤される nVersion 26.xまで – Java EE 8 / Jakarta EE 8対応 nVersion 27.xから31.xまで – Jakarta EE 10対応 nVersion 32.xから – Jakarta EE 11対応予定 46

Slide 47

Slide 47 text

47 OSSの実装︓Open Liberty IBMの開発するOSSでWebSphere Libertyの実装に使⽤される nVersion 20.0.0.3から – Java EE 7 / Java EE 8 / Jakarta EE 8対応 nVersion 21.0.0.12から – Java EE 7 / Java EE 8 / Jakarta EE 8 / Jakarta EE 9対応 nVersion 23.0.0.3から – Java EE 7 / Java EE 8 / Jakarta EE 8 / Jakarta EE 9 / Jakarta EE 10対応 nVersion 24.0.0.9か12から(予定) – Java EE 7 / Java EE 8 – Jakarta EE 8 / Jakarta EE 9 / Jakarta EE 10対応 – Jakarta EE 11対応予定 47

Slide 48

Slide 48 text

48 WebSphere Liberty / Open Libertyのバージョン n スケジュールベースのリリースで, 4週間ごとに新バージョンがでます(年12〜13回) n バージョン番号は4桁(IBM製品の共通仕様)で, – ⻄暦の下⼆桁 – 0 – 0 – 年内の通番(ほぼ,公開された⽉と⼀致) n 2024年の3⽉に公開された最新版はVersion 24.0.0.3 n 製品版WebSphere LibertyとOSS版Open Libertyのバージョンは共通 – 同じタイミングで同じバージョン番号が公開される – 新機能は,製品版とOSS版で,同時に公開 – ⼀部に製品版でのみ提供されている機能はあるが,標準API仕様などは両者で共通 • 例︓OSS版の23.0.0.12で動いた構成・アプリは,製品版の23.0.0.12でも完全に同じように動く 48

Slide 49

Slide 49 text

49 完全にモジュール化されたLiberty n 「アプリケーションから使⽤するAPI」「サーバー機能」は Featureというモジュールで提供されている n 構成ファイルで指定したFeature(と依存関係にあるFeature)のみが メモリにロードされて初期化される 49 jsp-2.3 jdbc-4.1 jaxrs-2.0 sessionDatabase-1.0 ssl-1.0 構成ファイル server.xml Servlet JSP JDBC SSL JAX-RS sessionDatabase 依存関係も ⾃動的に解決 JSON

Slide 50

Slide 50 text

50 Libertyのゼロマイグレーション・ポリシー n 新しい仕様のバージョンに対応するフィーチャーが追加されても,従来のフィーチャーも提供 – 例) 現在はServlet 5.0/6.0のFeatureが提供されているが, Servlet 4.0/3.1のFeatureも引き続き利⽤可能 n 構成ファイルを修正しないかぎり,バージョンを上げても新しい機能は有効にならない n Libertyのバージョンを更新しても,アプリケーションや構成の「マーグレーション」は不要 50 servlet-4.0 servlet-5.0 servlet-5.0 servlet-6.0 Tomcat 11.x Liberty 21.0.0.12 ⼀般的なアプリケーションサーバー WebSphere Liberty servlet-4.0 Tomcat 10.x servlet-6.0 Liberty 23.0.0.3 Tomcat 9.x

Slide 51

Slide 51 text

51 Libertyは,過去の仕様も全部対応しています n 過去のJava EE/MicroProfileのFeatureを 削除する予定はありません – 「LibertyではJava EE 8の機能セットのサポート終了 のプランはまだありません。将来のJava SEのバージョ ンでJava EE 8と互換性のない変更が導⼊された場合、 Java EE 8の機能のサポート終了について計画する必要 があります。ですが、最新バージョンのJava SE 20や 次期の21ではそのような⾮互換性はありません。」 (Ian Robinson, IBM Application Runtimes CTO) n 当分の間,Java EE仕様のアプリケーションも 最新版のLibertyで実⾏することができます n Java SEの仕様のサポートはある時点で終了します – Java SE 8/11は,26.0.0.9までサポート予定 – Java SE 17は,27.0.0.9までサポート予定 51 Java EE 6* Java EE 7 Java EE 8 Jakarta EE 9.1 Jakarta EE 10 Java SE 8 Java SE 11 Java SE 17 Java SE 21 MicroProfile 1.0 MicroProfile 1.2 ... MicroProfile 4.0 MicroProfile 4.1 MicroProfile 5.0 MicroProfile 6.0 MicroProfile 6.1 WebSphere Liberty Open Liberty * 製品版でWeb Profileのみ対応

Slide 52

Slide 52 text

52 Open Libertyの主なパッケージ n All GA Features – 全部のFeatureが⼊っている / Version 24.0.0.3では266 Features – 配布ZIPサイズ︓332M byte n Kernel – Featureが⼀つも⼊っていない / featureUtilityコマンドで必要なFeatureを導⼊して使⽤する – 配布ZIPサイズ︓14M byte n Jakarta EE 10 – Jakarta EE 10 platformとMicroProfile 6のFeature – 配布ZIPサイズ︓133M byte n Java EE 8 – Java EE 8 platformとMicroProfile 4のFeature – 配布ZIPサイズ︓137M byte 52 https://openliberty.io/start/#runtime_releases こちらはバージョンが上がるにつれ, どんどん⼤きくなっていますが これらの配布サイズは ほとんど変化がありません

Slide 53

Slide 53 text

53 LibertyのfeatureUtilityコマンド n 指定されたFeatureをダウンロードして追加導⼊するコマンド – Maven Centralリポジトリーからダウンロードされる – ミラー・リポジトリーも指定できる(featureUtility viewSettingsの実⾏結果を参照) n 使い⽅1︓Featureを指定してダウンロードする – featureUtility installFeature jaxrs-2.1 jsonb-1.0 – 指定されたFeature(と,その依存しているFeature)を導⼊する n 使い⽅2︓サーバーを指定してダウンロードする – featureUtility installServerFeatures defaultServer – 指定されたサーバーのserver.xmlに構成されたFeatureを導⼊する n これ以外にも,Maven/GradleのビルドやDockerfile/Containerfileのビルド, サーバー環境のパッケージングなどでも,特定のFeatureだけ⼊れる⼿段が提供されている n 必要な機能だけを選んで導⼊できるので,実⾏環境が不必要に肥⼤することはない n Featureの⼀覧は,こちらを参照(製品版,OSS版で提供されているもの) – https://www.ibm.com/docs/ja/was-liberty/base?topic=management-liberty-features 53

Slide 54

Slide 54 text

54 Libertyを使⽤したjakarta名前空間への対応 n 移⾏できるものは,jakarta名前空間に移⾏する n 移⾏できないものは,javax名前空間のまま利⽤する 54 GFBUVSF.BOBHFS GFBUVSFTFSWMFUGFBUVSF GFBUVSFKTQGFBUVSF GFBUVSFKBYSTGFBUVSF GFBUVSFDEJGFBUVSF GFBUVSF.BOBHFS import javax.annotation.Resource; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.sql.DataSource; GFBUVSF.BOBHFS GFBUVSFTFSWMFUGFBUVSF GFBUVSFQBHFTGFBUVSF GFBUVSFSFTUGVM84GFBUVSF GFBUVSFDEJGFBUVSF GFBUVSF.BOBHFS import jakarta.annotation.Resource; import jakarta.servlet.ServletException; import jakarta.servlet.annotation.WebServlet; import jakarta.servlet.http.HttpServlet; import jakarta.servlet.http.HttpServletRequest; import jakarta.servlet.http.HttpServletResponse; import javax.sql.DataSource;

Slide 55

Slide 55 text

55 55 Java EE / Jakarta EEアプリの モダナイゼーション Application Serverから Frameworkへ

Slide 56

Slide 56 text

56 なぜJava EEは「モダンではない」と⾔われるか n 「アプリケーション・サーバー」という実装が, クラウドネイティブ化などのモダナイゼーションの阻害要因になっていた 56 開発環境 実働環境 コード作成 App Server導⼊ 構成 ビルド デプロイ 実⾏ n Java EEでは,開発者がコードを作成し, それをビルドするだけでは実⾏できない ことが多かった n あらかじめテスト環境,本番環境に アプリケーション・サーバーを導⼊し 必要な構成を済ませ その環境にアプリをデプロイして はじめて実⾏することができた n サーバーのメンテナンスが, 運⽤の⼤きな負荷に

Slide 57

Slide 57 text

57 「モダン」なJavaフレームワークでは n コードを作成し,ビルドしたら, それがそのままサーバーで実⾏可能 n 事前のサーバー導⼊は不要 n 実⾏時の構成も,すべてコードとして記述 n CI/CDなどの⾃動化も容易 57 開発環境 実働環境 コード作成 ビルド 実⾏

Slide 58

Slide 58 text

58 Open Liberty / WebSphere Libertyは「Framework」 58

Slide 59

Slide 59 text

59 ビルドで実⾏環境の全てを作成 n LibertyはMaven Centralリポジトリーから ⾃動でダウンロードされ,実⾏環境を構築 n 構成およびビルドされたアプリを追加し ビルド環境でテスト実⾏が可能 n その環境を,まるごと導⼊可能ZIP (や実⾏可能JAR)にパッケージング可能 59 サーバー構成 導⼊可能 ZIP ランタイムの指定 ビルド・ツール 実⾏可能 JAR or アプリ 開発環境 実働環境 コード作成 ビルド ZIP展開 実⾏ コード作成 ビルド 実⾏ または 開発環境 実働環境

Slide 60

Slide 60 text

60 Open Libertyのクイック・スターター 60 https://openliberty.io/start/ Mavenのプロジェクトを ダウンロードできる (64kBほどの⼩さなZIP) 展開してビルドしただけで, 完全に動作する Open Liberty環境ができあがる (数⾏書きかえれば製品版も) 開発環境にも 製品の事前セットアップは不要

Slide 61

Slide 61 text

61 Libertyは他にもモダナイズに必要な全ての性質をもつ n ランタイムのサイズ(メモリ・ディスク)の⼩ささ – 必要最⼩限のモジュール(Feature)に限定することで,ランタイムサイズの極⼩化が可能 n 短い起動時間 – 通常の環境でも数秒で起動 – Liberty InstantOnにより,数百msecでの起動も可能 n 実⾏環境の可搬性 – 実⾏OSや導⼊ディレクトリ,ネットワークアドレスに依存しない構成が可能で,環境をまるごとコピー可能 – 環境ごとの差異を環境変数で吸収可能 n インフラによるクラスタリングとの親和性 – 「⾃⾝によるクラスタリング機能」を完全に無効化し,メモリ・ディスクから取り除くことが可能 – KubernetesのIngressなど,コンテナ環境の負荷分散 AWSのALB,Azure Load Balancerなど,パブリック・クラウド環境の負荷分散との⾼い親和性 n コンテナ環境との親和性 – 様々な事前設定をおこなった公式イメージを提供 – Liberty Operatorにより,Kubernetes/OpenShift環境での管理作業の負荷の⼤幅な削減 61

Slide 62

Slide 62 text

62 あなたのJava EEアプリを簡単にチェック n 移⾏チェックツールを無償で公開しています n Migration Toolkit for Application Binaries – https://www.ibm.com/support/pages/migration-toolkit-application-binaries • アプリのEAR/WARを直接分析し,使⽤されているAPIや機能を調査 • アプリケーションがWebSphere Liberty/Open Libertyで実⾏することができるか分析 • ソースやが不要で,サーバーでのツール実⾏も必要なく簡易に調査が実施できる 62

Slide 63

Slide 63 text

63 Migration Toolkit for Application Binaries n コマンドラインから以下のように実⾏ java -jar binaryAppScanner.jar --sourceJava=[oracle5|oracle6|oracle7|oracle8|ibm5|ibm6|ibm7|ibm8] --sourceAppServer=[weblogic|jboss|tomcat|was90|was855|was80|was70] --targetJava=[ibm8|java11|java17|java21] --targetAppServer=liberty n デフォルトでは結果はHTMLファイルとして出⼒ n テクノロジー評価 – アプリケーションで使⽤されているJava EE/Jakarta EEのAPIの⼀覧 n マイグレーション分析評価 – Libertyへの移⾏に当たって修正が必要なコードや構成の⼀覧 n インベントリー – アプリケションに含まれる外部ライブラリや,定義されているServlet/EJBなどのオブジェクトの数 n Liberty構成 – アプリケーションをLibertyで稼働させるのに必要なFeatureの⼀覧 63

Slide 64

Slide 64 text

64 64 最後に お知らせと宣伝

Slide 65

Slide 65 text

65 Qiitaでハンズオン記事を公開しています n JDK+VS Codeが導⼊されていれば無料で実施できるOpen Libertyのハンズオン 65 https://qiita.com/TTakakiyo/items/5f09be651bec34885c6e

Slide 66

Slide 66 text

66 WebSphere Liberty / Open Liberty コミュニティサイト nhttps://ibm.biz/JapanWebSphereUG – Japan WebSphere User Group – ログイン無しでどなたでも参照できます – 無料のIBM IDを登録いただければ ディスカッション・Q&Aなどの 書き込みもできます – IBMからの技術情報 – 各種イベントの情報もお伝えします︕ 66