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
Von "Enterprise" zu "Reactive" (JAX 2015)
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Lutz Hühnken
April 22, 2015
Programming
44
0
Share
Von "Enterprise" zu "Reactive" (JAX 2015)
Vortrag "Von Enterprise zu Reactive" von der JAX 2015.
Lutz Hühnken
April 22, 2015
More Decks by Lutz Hühnken
See All by Lutz Hühnken
Building a Bank (with DDD, Microservices, and Autonomous Teams)
lutzh
0
110
OOP Munich Night School - EDA is More Than Events - 3.2.2025
lutzh
0
190
Events, Workflows, Sagas: Complex Flows in Distributed Applications (2024-11-12 Software Architecture Gathering, Berlin)
lutzh
0
150
Event-Driven Architecture - 10 Jahre klüger
lutzh
0
200
The Unreasonable Effectiveness of Events at BOBKonf Berlin 2024
lutzh
1
270
Managing Architecture - LeadDev Berlin - 2023-12-05
lutzh
0
180
Microservices need Microworkflows w-jax Munich 2023
lutzh
0
140
Events, Workflows, Sagas? Keep Your Event-driven Architecture Sane at Developer Week Nuremberg
lutzh
0
96
Events, Workflows, Sagas at KanDDDinsky Berlin 2022
lutzh
0
480
Other Decks in Programming
See All in Programming
作って学ぶ、 JSX (TSX) ランタイムの基本
syumai
7
1.5k
JavaDoc 再入門
nagise
0
260
The Arts and Crafts of Work in the AI Era — Toward Mastery in Software Development
kuranuki
1
710
権限チェックの一貫性を型で守る TypeScript による多層防御
mnch
4
1.1k
jQueryをバージョンアップする前に使いたいjQuery Migrate
matsuo_atsushi
0
170
Claspは野良GASの夢をみるか
takter00
0
160
OSもどきOS
arkw
0
400
Why Laravel apps break—Mastering the fundamentals to keep them maintainable
kentaroutakeda
1
330
Signal Forms: Beyond the Basics @ngBaguette 2026 in Paris
manfredsteyer
PRO
0
220
AI時代のUIはどこへ行く?その2!
yusukebe
19
6.5k
Java × distroless で 軽量なコンテナイメージを / Java on Distroless
contour_gara
0
470
タクシーアプリ『GO』の バックエンド開発のおける AI利活用と若者のすべて
pyama86
3
1.8k
Featured
See All Featured
From π to Pie charts
rasagy
0
200
The Straight Up "How To Draw Better" Workshop
denniskardys
239
140k
From Legacy to Launchpad: Building Startup-Ready Communities
dugsong
0
220
Leo the Paperboy
mayatellez
7
1.8k
YesSQL, Process and Tooling at Scale
rocio
174
15k
Practical Tips for Bootstrapping Information Extraction Pipelines
honnibal
25
1.9k
How to make the Groovebox
asonas
2
2.2k
Crafting Experiences
bethany
1
160
How Fast Is Fast Enough? [PerfNow 2025]
tammyeverts
3
600
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
17k
Statistics for Hackers
jakevdp
799
230k
The Impact of AI in SEO - AI Overviews June 2024 Edition
aleyda
5
1.1k
Transcript
Lutz Hühnken | @lutzhuehnken | Typesafe Von „Enterprise“ zu „Reactive“
Von Enterprise zu Reactive @lutzhuehnken Reactive „for the rest of
us“.. Big Data Web Scale HFT Tomcat Web MVC RDBMS
Von Enterprise zu Reactive @lutzhuehnken Was ist Enterprise? Im Sinne
dieses Vortrags: • Alles, was auf Java EE basiert • Insbesondere Servlet API basierte Webapps, z.B. auf Tomcat
Von Enterprise zu Reactive @lutzhuehnken Was ist Reactive?
Von Enterprise zu Reactive @lutzhuehnken Was ist Reactive? Behauptet doch
jeder von sich…
Von Enterprise zu Reactive @lutzhuehnken Was ist Reactive? Alles Akka,
oder was?
Von Enterprise zu Reactive @lutzhuehnken Mal anders: Fragen, die wir
immer wieder hören
Von Enterprise zu Reactive @lutzhuehnken WAR? Servlet Container? Web Layer
Library X (nutzt ThreadLocal) ?
Von Enterprise zu Reactive @lutzhuehnken Kann ich das nutzen mit
RDBMS/ JDBC? Backend Wie mache ich 2PC?
Von Enterprise zu Reactive @lutzhuehnken Thread per Request
Von Enterprise zu Reactive @lutzhuehnken n Threads per m Requests
Von Enterprise zu Reactive @lutzhuehnken n Threads per m Requests
Effekt: Kleinere Einheit der Nebenläufigkeit (Task level concurrency)
Von Enterprise zu Reactive @lutzhuehnken Kleiner Exkurs: Gilt auch für
Aktoren (Überhaupt: Gemeinsamkeit (einiger) reaktiver Systeme)
Von Enterprise zu Reactive @lutzhuehnken n Threads per m Requests
Was heißt das für ThreadLocal?
Von Enterprise zu Reactive @lutzhuehnken n Threads per m Requests
Was heißt das für I/O?
Von Enterprise zu Reactive @lutzhuehnken n Threads per m Requests
In Tomcat / Servlet Container?
Von Enterprise zu Reactive @lutzhuehnken Konsequenzen (alpha) • Servlet Container
• ThreadLocal • Blocking I/O werden zu Anti-Pattern. Vermeiden!
Von Enterprise zu Reactive @lutzhuehnken Jetzt habe ich aber so
etwas.. try { stmt = con.createStatement(); ResultSet rs = stmt.executeQuery(query); while (rs.next()) { String coffeeName = rs.getString("COF_NAME"); int supplierID = rs.getInt("SUP_ID"); float price = rs.getFloat("PRICE"); int sales = rs.getInt("SALES"); int total = rs.getInt("TOTAL"); System.out.println(coffeeName + "\t" + supplierID + "\t" + price + "\t" + sales + Blocking I/O, Sorgenkind JDBC
Von Enterprise zu Reactive @lutzhuehnken Isolieren! Bei vert.x „Worker Verticle“
Bei Play/Akka: Volle Kontrolle über Dispatcher Nicht nur für JDBC, generell für „blocking“ code
Von Enterprise zu Reactive @lutzhuehnken Konsequenzen (beta) • auf Servlet
Container und ThreadLocal verzichten • Blocking I/O vermeiden. Im Notfall: Isolieren.
Von Enterprise zu Reactive @lutzhuehnken Jetzt habe ich aber so
etwas.. @Transactional public static class GreetingService { @Inject private JmsTemplate jmsTemplate; @PersistenceContext private EntityManager entityManager; public void createGreeting(String name) { Greeting greeting = new Greeting(name); this.entityManager.persist(greeting); this.jmsTemplate.convertAndSend("greetings", greeting); … Verteilte Transaktion
Von Enterprise zu Reactive @lutzhuehnken
Von Enterprise zu Reactive @lutzhuehnken Vermeiden this.entityManager.persist(greeting); this.jmsTemplate.convertAndSend("greetings", greeting); …
Warum nicht separater Abgleich (Reconciliation)? In unserem kleinen Beispiel:
Von Enterprise zu Reactive @lutzhuehnken Trennen Jeder 2 PC kann
durch asynchrones Messaging ausgedrückt werden!
Von Enterprise zu Reactive @lutzhuehnken 2PC => Messaging Kleine Einschränkung
- Voraussetzungen: •tentative operations •at-least-once delivery •idempotent messages Item-B Cancellation Tentative Op Item-A
Von Enterprise zu Reactive @lutzhuehnken Verwerten Service A (Reactive) Service
B (Legacy)
Von Enterprise zu Reactive @lutzhuehnken Konsequenzen (1.0) • auf Servlet
Container und ThreadLocal verzichten • Blocking I/O vermeiden. Im Notfall: Isolieren. • Distributed Tx: Vermeiden, trennen, verwerten
Von Enterprise zu Reactive @lutzhuehnken Warum das Ganze? • Wir
haben gesehen: Ich kann auch meine „normale“ Geschäftsanwendung reactive machen, und dabei Kompromisse eingehen. • Was bringt mir das?
Von Enterprise zu Reactive @lutzhuehnken • Heißt nicht nur „web
scale“. • Effizient sein. Moderne Hardware nutzen (Many Core, NUMA) • Von Innovation profitieren (s. Brian Goetz gestern)
Von Enterprise zu Reactive @lutzhuehnken Nicht von mir! Sondern von
John Rose, Java VM Architect, JFokus, Stockholm, February 2015
Von Enterprise zu Reactive @lutzhuehnken • Prinzipien der Supervision &
Isolation • Let it crash!
Von Enterprise zu Reactive @lutzhuehnken • Spaß!! • Ernsthaft. All
das ist nicht entwickelt worden, um unser Leben komplizierter zu machen. Sondern einfacher! • Wie würdest du es mit Menschen lösen..?
Von Enterprise zu Reactive @lutzhuehnken Vielen Dank
[email protected]
Twitter: @lutzhuehnken
Kommt zum Typesafe-Stand! (In der Nähe der Garderobe) Geht zu den anderen „Reactive“ Vorträgen!