Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Java in containers and serverless
Search
Shigeki Shoji
November 30, 2023
Technology
0
360
Java in containers and serverless
Shigeki Shoji
November 30, 2023
Tweet
Share
More Decks by Shigeki Shoji
See All by Shigeki Shoji
アジャイルテストで高品質のスプリントレビューを
takesection
0
160
Introduction to kanjava
takesection
0
95
LT Slide 2025-04-22
takesection
0
150
Instructional Designer
takesection
0
140
Zero to Hero
takesection
0
220
Fargateを使った研修の話
takesection
0
320
20240730_kanjava.pdf
takesection
0
150
JavaのJCP会員になろう
takesection
0
110
JAWS-UG Okayama 2024 LT
takesection
0
110
Other Decks in Technology
See All in Technology
Zephyr(RTOS)にEdge AIを組み込んでみた話
iotengineer22
0
220
Databricks AI/BI Genie の「値ディクショナリー」をAmazonの奥地(S3)まで見に行く
kameitomohiro
1
340
Data Hubグループ 紹介資料
sansan33
PRO
0
2.2k
AWSでAgentic AIを開発するための前提知識の整理
nasuvitz
2
220
会社を支える Pythonという言語戦略 ~なぜPythonを主要言語にしているのか?~
curekoshimizu
1
150
CNCFの視点で捉えるPlatform Engineering - 最新動向と展望 / Platform Engineering from the CNCF Perspective
hhiroshell
0
110
Biz職でもDifyでできる! 「触らないAIワークフロー」を実現する方法
igarashikana
3
1.1k
CoRL 2025 Survey
harukiabe
1
230
[OCI Skill Mapping] AWSユーザーのためのOCI – IaaS編(Compute/Storage/Networking) (2025年10月8日開催)
oracle4engineer
PRO
1
100
物体検出モデルでシイタケの収穫時期を自動判定してみた。 #devio2025
lamaglama39
0
250
「魔法少女まどか☆マギカ Magia Exedra」の多様なバトルの開発を柔軟かつ効率的に実現するためのPure C#とUnityの分離について
gree_tech
PRO
0
130
AIとともに歩んでいくデザイナーの役割の変化
lycorptech_jp
PRO
0
640
Featured
See All Featured
Practical Orchestrator
shlominoach
190
11k
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
48
9.7k
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
12
1.2k
Site-Speed That Sticks
csswizardry
13
910
Facilitating Awesome Meetings
lara
56
6.6k
Building a Modern Day E-commerce SEO Strategy
aleyda
44
7.8k
The MySQL Ecosystem @ GitHub 2015
samlambert
251
13k
How to train your dragon (web standard)
notwaldorf
97
6.3k
Dealing with People You Can't Stand - Big Design 2015
cassininazir
367
27k
Learning to Love Humans: Emotional Interface Design
aarron
274
41k
BBQ
matthewcrist
89
9.8k
4 Signs Your Business is Dying
shpigford
185
22k
Transcript
コンテナ・サーバーレス環境に 対応しよう 2023年11月30日 Shigeki Shoji
庄司重樹 受賞歴 AWS 2023 Japan Top Engineers 資格 AWS認定12冠 (All
Certifications) Professional Scrum Product Owner I Professional Scrum Master I Professional Scrum Developer I 翻訳レビュー Sam Newman著「モノリスからマイクロサービスへ」 2020. O’Reilly. コミュニティ AWS Community Builders program、関ジャバ、JJUG、Scala関西、もめんと会他 2
イベントの 宣伝 梅田で「もめんと会」します。よろしくお願いしま す! https://momentocommunity.connpass.com/event/3 02306/ 3
アジェンダ • 進化的アーキテクチャ • Javaの課題 • サイズを小さく • 起動時間を短く •
まとめ 4
進化的 アーキテ クチャ 漸進的 誘導的 多元的 “Monoliths are not dinosaurs”
- @WERNER https://www.allthingsdistributed.com/2023/05 /monoliths-are-not-dinosaurs.html 5
なぜJava? • 漸進的な小さな変更のために、動いているモ ジュールを再利用したい • 言語を変えて漸進的な小さな変更を実現する のは難しいかもしれない。どちらかというと 破壊的変更につながる場合が多そう 6
Javaは進化 を続けて いる JVMは人類の叡智の結晶だ 7
Quiz コンテナ・サーバーレスのアプリケーションで重要なことは? 1. イメージサイズの小ささ 2. 依存ライブラリのロードの俊敏さ 3. 起動の俊敏さ 8
俊敏なス ケール要 求 • 以前はサーバの増設、キャパシティを増やす のに数ヶ月かかることも多かった • 仮想化の進化、クラウドの登場により、今で は1秒以内でサーバのスケールが要求されるこ とも
9
高速な起 動を阻む もの達 • イメージのロードにかかる時間 • クラスファイルの解釈、Just In Timeコンパイ ラがコンパイルする時間
• 必要なリソースへの接続等の初期化 10
イメージ のロード にかかる 時間の短 縮 • コンテナの場合 distroless などの小さく不要 なものを含まないベースイメージを選択しよ
う • jlinkを使って小さく不要なものを含まない Javaランタイムを準備しよう https://learn.microsoft.com/ja- jp/java/openjdk/java-jlink-runtimes 11
jlink • Java 9 以降で使用可能 • 必要なモジュールだけのJREを作れる 12
Nativeイ メージに する • メリット • イメージサイズを大幅に小さくできる • 起動の高速化が期待できる •
デメリット • リフレクションが使えない場合がある等、 使える言語機能に制約があり、コードの修 正が必要になるかもしれない • JITによる最適化が期待できない 13
CRaCを使 う • メリット • プロビジョニングする同時実行数の見積も りが不要 • SnapStart にかかる課金がない
• デメリット • AWS LambdaではArmをサポートしていな い • 初期化時に外部リソース等を保持している 場合、Runtime hooksの実装が必要になる かもしれない • Java 11 以降 (Java 11、Java 17、Java 21) のマネージドランタイムのみサポート • Provisioned Concurrency との併用ができ ない等 14
CRaC があるとき〜 15 https://github.com/takesection-sandbox/aws-lambda-scala
CRaC がないとき〜 16
トレンド InfoQ Java Trends Report - November 2023で は、CRaC がイノベータに
https://www.infoq.com/articles/java-trends- report-2023/ 17
起動した インスタ ンスを保 持する • メリット • Javaランタイムに限らず、また Intel でも
Arm でもどちらにも適用可能 • デメリット • 5分単位での課金 • 必要なインスタンス数を見積もる必要があ る 18
コネク ション プール • RDBなどのリソースに毎回接続すると、認証 等にかかるオーバーヘッドがある。これを回 避するためにあらかじめ一定量の接続を保持 して、必要に応じてこれを払い出すパターン がある。 •
複数スレッドが異なるトランザクションを実 行する、伝統的なサーバアプリケーションで は有用だったが、サーバーレスのように1イ ンスタンス1トランザクションという処理だ と基本的に不要。さらにスケールした場合に 使われない接続が大量に発生することになる が、これはRDB側にとって害となる。 • ただし、接続が切れた時に自動的に再接続す る機能は嬉しいかもしれない。 19
コンポー ネントス キャンに 注意 • Spring Framework等にあるコンポーネントス キャンは依存ライブラリから必要なクラスを 見つけるときzipにアーカイブされたファイル 一覧を読み取り、インジェクションを実行す
る。一般的にこの処理は遅く、起動時間に影 響する。 • クラス数の少ないパッケージをコンポーネン トスキャンの対象に選ぶ。 https://github.com/takesection- sandbox/scan-classpath 20
まとめ • イメージサイズを小さくしよう • 初期化処理はほどほどに • CRaC、初期化済みインスタンスの活用、 Native化のメリット、デメリットを検討して 採用しよう 21
22 ご清聴ありがとうございました