You are viewing content from a past/completed QCon Plus - November 2020

Session

Starting Fast: Investigating Java's Static Compilation Landscape

We've always wanted fast startup for our applications but the meaning of "fast" has changed radically with the cloud revolution.  This increasing focus on fast startup has put greater pressure on the JVM to start faster and has driven the Java language to look at ways of delaying operations until they're needed.  New frameworks like Quarkus are changing how we develop applications by moving work from runtime to build time. No more classpath searches during startup to find annotations.  But that's not the whole story, Graal's SubstrateVM compiles entire applications into compiled images and OpenJDK has announced Project Leyden to focus on the statically compiled Java space.  What does this mean for you as a developer?  And for your application?  Find out why your technology choices today may affect the success at adopting these options.

Main Takeaways

1 Find out what are some options to start a Java application faster.

2 Learn about Graal Substrate VM, Quarkus, Project Leyden, and others, how they can help starting a Java app faster.


Who are you targeting in this talk? What's the level that you're expecting to kind of hit on?

Definitely the architects and the senior developers: people who are deciding what the shape of the application is going to be in the future, how they're going to deploy it, how dense you can get your application, really how much memory it's going to take to deploy it, and all the characteristics that go into doing that deployment.

What are some things that you might recommend for someone to look at first?

To be well prepared for it, I think it makes sense to take a look at frameworks that are using Graal SubstrateVM. So take a look at Quarkus, take a look at the Micronaut, understand what's different about those frameworks compared to the traditional Java EE frameworks. And then if you really want to get in-depth, take a look at the Linux CRIU (Checkpoint Restore in Userspace) project, which checkpoints a Linux process allowing it to be restored from that point later. That will help lay the foundation for looking at what goes into making Java fast and ways that it may evolve in the future.

If I'm a Java developer, and come to your talk, what will I walk away with?

A sense of some of the pressures that are on the Java ecosystem. Everybody wants their application to start fast today. We've gone from wanting Java just to be fast, and now we want it to start fast as well. That puts pressure on the language and how the language evolves, how the VM evolves, and then also how the frameworks evolve. The ultimate solution in any of these approaches depends on what application developers are willing to adopt, what changes they're willing to make. As an application developer or as an architect, the ball is really in your court. If enough of you back a particular solution, that's likely to be the one that drives where the industry goes. Make sure that you take a look around and are picking the right one that you want to be using in the future.

Is this talk focused on specific solutions, implementations, or is it about techniques that you can apply to many different solutions?

It's more about understanding the landscape and looking at where time goes in a Java application. We know that class loading, in particular, takes a lot of time when you're trying to get your application started, loading classes, and of course initializing them. This talk is looking at what are the ways - the tools and approaches -  you can use to avoid paying those costs? It comes down to moving more work to build time versus doing it at runtime, or looking at techniques that allow you to check point your running application so you could do that work once and restart from that point next time.


Speaker

Dan Heidinga

Principal Software Engineer @RedHat

Dan Heidinga wears two hats: first as an Eclipse OpenJ9 project lead, and the second as a Red Hat employee. Fortunately, both of those hats let him hack on the OpenJ9 JVM which he's been doing since 2007. Along the way he's been part of the Expert Groups for multiple JSRS including JSR...

Read more

From the same track

Session

Project Valhalla: Bringing Performance to Java Developers

Tuesday Nov 17 / 02:40PM EST

Modern computing has come a long way in the past decade, but are you taking advantage of all it has to offer? Memory latency is the big killer of computing performance and having compact data structures is key to solving this. This session explains the advances being made in Project Valhalla to...

Tobi Ajila

Java Runtime Developer for the OpenJ9 VM team @IBM

Session

Enabling Java: Windows on Arm64 – A Success Story!

Tuesday Nov 17 / 01:00PM EST

This is a tale of 3 engineers and their quest to bring Java to every Windows on Arm developer.    We will provide:  a quick timeline of our development efforts and Microsoft’s journey into OpenJDK land (spoiler alert: we were welcomed with open arm(s) (pun intended)),  a...

Monica Beckwith

Java Champion, First Lego League Coach, passionate about JVM Performance @Microsoft

PANEL DISCUSSION

Sustaining and Growing an Active Community in a Mature Platform

Tuesday Nov 17 / 03:30PM EST

Java is no longer the new kid on the block. However, one of its great strengths is the quality of the community it has built up over the last 25 years?  How can we help that community continue to grow, thrive, and attract new members - especially from younger developers who have recently...

Mala Gupta

Developer Advocate @JetBrains

Venkat Subramaniam

Founder of Agile Developer, Inc., Creator of agilelearner.com & Professor at the University of Houston

James Gough

Lead Architect @MorganStanley

Rémi Forax

Maître de Conférences at the University of Marne-la-Vallée & Java Champion

View full Schedule

Less than

16

weeks until QCon Plus May 2022

Level-up on the emerging software trends and practices you need to know about.

Deep-dive with world-class software leaders at QCon Plus (Nov 1-12, 2021).

Save your spot for $549 before February 7th

Register