-
Notifications
You must be signed in to change notification settings - Fork 96
Presentations
Our team gives many presentations at conferences and meetups all over Europe and elsewhere. We collect these here.
Johannes Bechberger (blog)
Johannes Bechberger is a JVM developer working on profilers and their underlying technology in the SapMachine team at SAP. This includes improvements to async-profiler and its ecosystem, a website to view the different JFR event types, and improvements to the FirefoxProfiler, making it usable in the Java world. He started at SAP in 2022 after two years of research studies at the KIT in Java security analyses. His work today comprises many open-source contributions and his blog, where he regularly writes on in-depth profiling and debugging topics. He also works on hello-ebpf, the first eBPF library for Java.
Since 2023, he's been touring Europe's Java User Groups and conferences, like JavaZone and Devoxx Belgium, to speak on various topics.
All of the following talks are his.
Alternative titles: Profiler Tools for Java | Your Java Application Is Slow? Check Out These Open-Source Profilers
Profilers help to analyze performance bottlenecks of your application – if you know which to use and how to work with them.
There are many open-source profilers, like async-profiler or JMC. This talk will give you insights into these tools, focusing on understanding the basic concepts of profiling like flame graphs and more, the usage of async-profiler and JMC, and the advantages and disadvantages of the different tools.
The talk will end with personal insights into my profiler development and a successful profiling workflow that resulted from this. https://speakerdeck.com/parttimenerd/unleash-the-power-of-open-source-java-profilers
Collection of reading material
Date | Event | Location | Links |
---|---|---|---|
Apr 25, 2024 | JUG Berlin-Brandenburg | Berlin, Germany | Schedule |
Nov 21 - 23, 2023 | JCon World | Online | Schedule |
Oct 18 - 19, 2023 | Basel One | Basel, Switzerland | Schedule |
Sep 12, 2023 | JavaForum Nord | Hannover, Germany | |
Sep 6 - 7, 2023 | JavaZone | Oslo, Norway | Schedule, Recording, Slides |
Jun 14, 2023 | Karlsruher Entwicklertag | Karlsruhe, Germany | |
Jun 7, 2023 | JDriven Full Stack Conference | Nieuwegen, Netherlands | |
May 31, 2023 | JUG Milano | Milan, Italy | Schedule, Recording |
Mar 27 - 29, 2023 | QCon London | London, UK | Schedule, Recording |
Oct 18, 2022 | JUG Karlsruhe | Karlsruhe, Germany | Schedule, Recording |
Alternative title: Write your own Java Profiler in 240 lines of pure Java
Profilers help to analyze performance bottlenecks of your application if you know how to use them. Getting to grips with profilers helps to understand how they work: Profilers aren't rocket science. A usable Java profiler can be written in 240 lines of pure Java code, allowing you to fix performance issues and add custom features quickly.
This talk will give the fundamentals of Java profiling and how Java profilers typically work, followed by a detailed explanation of how to develop a functioning profiler in a few lines of Java code. This talk will also explain how you can use it in production to analyze performance issues and show briefly how to work with a widely used open-source profiler based on the same principles.
Collection of reading material
Date | Event | Location | Links |
---|---|---|---|
Jun 28, 2024 | KCDC | Kansas City, US | Schedule |
May 29, 2024 | jPrime | Sofia, Bulgaria | Schedule |
Apr 4, 2024 | JUG Vilnius | Vilinus, Lithuania | Schedule |
Feb 21 - 23, 2024 | ConFoo | Montreal, Canada | Schedule |
Nov 9, 2023 | J-Fall | Ede, Netherlands | Recording |
Oct 2 - 6, 2023 | Devoxx Belgium | Antwerp, Belgium | Schedule, Slides, Recording |
Sep 14 - 15, 2023 | code.talks | Hamburg, Germany | Schedule, Recording |
Jul 13, 2023 | JUG Mannheim | Mannheim, Germany | Schedule |
Jun 14, 2023 | Karlsruher Entwicklertag | Karlsruhe, Germany | C++ Version with the title "Writing a Java Profiler from Scratch" |
Jun 5, 2023 | OpenValue München | Munich, Germany | Schedule |
Profilers are great tools in your toolbox, like debuggers, when solving problems with your Java application. I'll tell you some of their problems and a technique to cope with them in this talk.
There are many open-source profilers, most notably JFR/JMC, and async-profiler, that help you to find and fix performance problems. But they are just software themself, interwoven with a reasonably large project, the OpenJDK (or OpenJ9, for that matter), and thus suffer from the same problems as the typical problems of application they are used to profile.
Date | Event | Location | Links |
---|---|---|---|
Jun 8 - 11, 2023 | Gulaschprogrammiernacht | Karlsruhe, Germany | Schedule, Slides, Recording |
I'll present you with all the techniques to write a Java agent and javassist based instrumentation code to find unused classes and dependencies in your project. Knowing which classes and dependencies are not used in your application can save you from considering the bugs and problems in these dependencies and classes if you remove them, helping to guard against supply chain attacks.
Java agents and instrumentation of a few lines of code can save you a lot of effort and implementing them is great fun :)
Reading material: Instrumenting Java Code to Find and Handle Unused Classes and Class Loader Hierarchies
Date | Event | Location | Links |
---|---|---|---|
Jul 31, 2024 | Java Forum Stuttgart | Stuttgart, Germany | Schedule, Slides |
Mar 7, 2024 | Voxxed Days Zürich | Zürich, Switzerland | Schedule, Slides, Recording |
Jun 8 - 11, 2023 | Gulaschprogrammiernacht | Karlsruhe, Germany | Schedule, Slides, Recording |
Alternative title: Debugging Unveiled: Exploring Debugger Internals to Make You a Better Developer
Debuggers are indispensable tools for Java developers, empowering them to conquer bugs and unravel complex systems. But have you ever wondered how they work? Curious about the implementation of features like conditional breakpoints and remote debugging? Wondering about all the cool features in modern IDEs, how they are implemented and how IDEs even communicate with your JVM?
Join me for a deep dive into debuggers, unlocking their secrets and hidden gems to maximize their potential.
Reading material: Debugging-related blog posts, JDWP-tunnel, Personal talk page
Date | Event | Location | Links |
---|---|---|---|
Jul 2, 2024 | NYJavaSIG | New York City, USA | Schedule |
Jun 3 - 5, 2024 | Karlsruher Entwicklertag | Karlsruhe, Germany | Schedule |
Apr 9 - 11, 2024 | JavaLand | Nürburgring, Germany | Deep-Dive, Schedule |
Feb 21 - 23, 2024 | ConFoo | Montreal, Canada | Schedule |
Jan 17, 2024 | WeAreDevelopers Java Day | Online | Schedule |
Nov 7, 2023 | JUG Karlsruhe | Karlsruhe, Germany | Schedule, Slides |
Oct 12, 2023 | JUG Darmstadt | Darmstadt, Germany | Schedule, Slides |
eBPF is buzzing all over the cloud native world, as the cutting-edge technology reshaping the way we understand performance, security, and observability within kernel space. Java, with its recent strides in modernization and optimization, from enhancing startup times to facilitating native execution and advancing machine learning applications, stands at the cusp of this transformative era.
Join us in this journey, where we will embark on an ambitious challenge to write and build a high-throughput firewall leveraging the combined power of eBPF and Java. We'll start with a deep dive into eBPF's capabilities for kernel-level packet manipulation, then transition to how Java's latest advancements, particularly through Project Panama, enable seamless native code invocation and interoperability. Our focus will then converge to a hands-on demonstration of building a simple firewall using eBPF and Java, integrating kernel-level operations with high-level programming for real-time performance enhancements.
Attendees will gain practical insights into deploying eBPF programs from Java using the hello-ebpf library, managing packet flows efficiently, and implementing firewall rules with precision, leveraging the strengths of both worlds.
Reading material: My blog series on developing hello-ebpf, a Java library for eBPF. More resources here
Date | Event | Location | Links |
---|---|---|---|
Nov 6 - 8 | Øredev | Malmö, Sweden | Schedule, joint talk with Mohammed Aboullaite |
Oct 22 - 24 | Open Community Experience | Mainz, Germany | Schedule |
Oct 7 - 11 | Devoxx Belgium | Antwerp, Netherlands | Schedule, joint talk with Mohammed Aboullaite |
Sep 26 - 27, 2024 | InfoQ Dev Summit | Munich, Germany | Schedule |
Sep 3 - 5, 2024 | JavaZone | Oslo, Norway | Schedule, Slides, Recording, joint talk with Mohammed Aboullaite |
Aug 28, 2024 | Copenhagen Developer Festival | Copenhagen, Denmark | Schedule |
Aug 23, 2024 | Suisse JUG | Luzern, Switzerland | Schedule, Slides |
Aug 22, 2024 | Suisse JUG | Zürich, Switzerland | Schedule, Slides |
Python 3.12 introduced a new low impact monitoring API with PEP669 which can be used to implement far faster debuggers than ever before. This talk will give you an introduction to the new API and show you how it can be used to write a simple debugger from scratch.
Date | Event | Location | Links |
---|---|---|---|
Oct 31 - Nov 3, 2024 | PyCon France | Strasbourg, France | |
Sep 25 - 26, 2024 | PyData Paris | Paris, France | Schedule |
Apr 22 - 24, 2024 | PyCon.DE | Berlin, Germany | Schedule Slides |
Feb 3 - 4, 2024 | FOSDEM | Brussels, Belgium | Schedule with Recording, Slides |
Python long lagged a good monitoring and profiling API. It had only the simplistic sys.settrace API, which had a high overhead and couldn't be configured appropriately. The new API, released in October 2023, will change this by offering a proper fine-grained and well-designed monitoring API while also making the commonly used operations fast.
This talk will give you an introduction to the new API and its design major design decisions and show you how you can use it to write a simple debugger from scratch.
Date | Event | Location | Links |
---|---|---|---|
May 31, 2024 | Gulaschprogrammiernacht | Karlsruhe, Germany | Schedule |
May 2, 2024 | budapest.py | Budapest, Hungary | Event, Interview |
Apr 4, 2024 | PyCon Lithuania | Vilnius, Lithuania | Schedule, Slides, Recording |
Feb 3 - 4, 2024; FOSDEM; Brussels, Belgium
A Java thread in the JVM regularly checks whether it should do extra work besides the execution of the bytecode. This work is done during so-called safepoints. There are two types of safepoints: local and global. This allows the JVM to do activities like method deoptimizations or stop-the-world garbage collections, where the amount of concurrency should be limited. But how do they actually work?
This talk covers the implementation of global and local safepoints in the OpenJDK.
Feb 4 - 5, 2023; FOSDEM; Brussels, Belgium
Like many programming communities, the Java community lacks a simple open-source profiling UI. In the quest to build such a UI, I found the Firefox Profiler to be the closest to an adaptable polyglot profiling UI. This talk presents my Java JFR Profiler plugin for IntelliJ and gives an overview of how to adapt and integrate the Firefox Profiler to use it to view profiling data from different sources, like JDK Flight Recordings.
This talk is based on my blog posts Firefox Profiler beyond the web and Using Firefox Profiler beyond the web which cover my work on my Firefox Profiler based IntelliJ Plugin.
Feb 4 - 5, 2023; FOSDEM; Brussels, Belgium
Java profiling relies heavily on the AsyncGetCallTrace API. But this API has major drawbacks: It is unofficial, not well-tested, and omits important information. I propose AsyncGetStackTrace (JEP Candidate 435) as an improved replacement.
This talk will give an overview of AsyncGetCallTrace and AsyncGetStackTrace, their implementations, differences, and use cases, it is based on my blog post AsyncGetStackTrace: A better Stack Trace API for the JVM and related to the JEP Candidate 435.
Sep 11, 2024; eBPF Summit; Online
Sched_ext allows you to write a Linux scheduler with eBPF. Now that it finally comes to the mainline kernel, we want to make it accessible to a new group of people: Java developers. With our prototypical hello-ebpf library, it's now possible to write Linux schedulers and more using Java.
Join me in learning about sched_ext and how to write a basic scheduler implementation in "pure" Java.
Sep 18 - 20, 2024; Linux Plumbers Conference; Vienna, Austria
While there are eBPF libraries for languages like Rust and Go, there are none for Java, one of the most popular programming languages. We developed the hello-ebpf Java library to change this. Its aim is to integrate eBPF programs seamlessly into Java applications, making it possible to write the eBPF programs themselves directly in Java.
In this talk, we show the technology behind the library, its use, and how to use it to easily implement a basic packet filter and a simple Linux scheduler without writing a single line of C code.
Feb 2 - 3, 2019; FOSDEM; Brussels, Belgium
OracleJDK, OpenJDK, AdoptOpenJDK, OpenJ9, Zulu, IcedTea, Liberica, SapMachine, GraalVM, SubstrateVM. 8, 9, 10, 11, 12, 18.3, 18.9, short-term, mid-term, long-term support release, security updates. GPLv2, Classpath Exception, Oracle Binary Code License, Technology Network License Agreement. Field of use restriction, private and commercial use, reference implementation, substantially derived, TCK/JCK, Oracle Contribution Agreement, OpenJDK Community TCK License Agreement (OCTLA), Java Community Process (JCP), Java Specification Request (JSR), Java Enhancement Proposal (JEP), Preview Features, Incubator Modules, Java (TM), Java SE compatibility, OpenJDK trademark notice.
Confused? Come and hear from Java and OpenJDK veteran Volker Simonis how the Java world has been radically turned inside out in the last year and how this impacts you as a Java user or developer. After the talk you'll have a clear understanding what's going on in the Java ecosystem and you'll be ready to plan your or your companies future Java strategy.