Cursus
Formation JAVA Optimisations de code Java
Objectifs
Identifier les principes de fonctionnement d’une JVM.
Développer et démarrer un agent JVMTI.
Appliquer des "Guide Lines" de programmation pour optimiser les performances.
Déterminer le fonctionnement du Garbage Collector et ses évolutions.
Recycler les ressources de la JVM et optimiser les applications multithreadées.
Utiliser des outils graphiques de monitoring et de profiling Java.
Pré-requis
Participants
Programme de formation
QUELQUES RAPPELS FONDAMENTAUX
L'environnement J2SE (Java 2 Standard Edition)
- Concepts fondamentaux (ClassLoader, JIT, GC, Gestionnaire d'exceptions...)
- JVMPI (Java Virtual Machine Profiling Interface)
- Quelques outils du J2SE (javap...)
Notion de byte code
- Utilisation du désassembleur javap
- Notions de pile et de tas (Stack & Heap)
- Mécanisme de déclarations : variables locales et attributs
- Appels de méthodes en assembleur
Quelques considérations sur les performances
- Temps d'exécution VS taille de l'exécutable
- Génie logiciel VS Performances
DÉVELOPPEMENT D'AGENTS JVMTI
Concepts fondamentaux de JVMTI
- Les différentes versions l'interface JVMTI
- Les évènements JVMTI
Codage d'agents JVMTI
- Traquer l'activité du ClassLoader
- Traquer l'activité en termes d'allocations dynamiques
- Traquer l'activité en termes d'appels de méthodes
"GUIDE LINES" DE PROGRAMMATION
Utiliser correctement les Logger
- Log4J...
Fonctionnement de l'instruction switch
Limitation d'instances temporaires
Utiliser correctement les chaînes de caractères
Utilisation des collections Java
- Choisir les bons algorithmes face aux besoins
- Collection synchronisées ou non (Vector vs ArrayList...)
- Les différentes techniques de parcours d'une collection
- Problèmatiques de l'autoboxing et du unboxing
Utilisation de tableaux Java typés
- Accès indexés aux valeurs
- Traitements des valeurs de types primitifs
Encapsulation VS performance
LE GARBAGE COLLECTOR (GC)
Aspects fondamentaux
- Tâches du garbage collector : libération et défragmentation
- Les différents algorithmes utilisés
Fonctionnement du Garbage Collector de la JVM Hotspot (Oracle)
- Monitorer l'activité du GC
- Collectes mineures et collectes majeures
Comparaison Hotspot/OpenJ9
Paramétrage du Garbage Collector de la JVM HotSpot
- Gestion de la taille des Heap (-Xmx, -Xms, -XX:NewRatio, -XX:SurvivorRatio...)
- Libération incrémentale des ressources
Les évolutions du GC au fil des versions de Java
RECYCLONS LES RESSOURCES DE LA JVM
Utilisation d'un pool d'instances
- Implémentation d'un pool d'instances
- Utilisation d'un pool d'instances
- Etude du comportement du GC via un agent JVMTI
Applications multithreadées
- Monitoring via JVMTI sur l'utilisation des threads
- Le package java.util.concurrent
- Utilisation de pool de threads
- Gestion de la synchronisation de vos threads
SoftReferences et WeakReferences
OUTILS GRAPHIQUES DE MONITORING ET DE PROFILING
La JConsole
- Présentation du modèle JMX (Java Monitoring eXtensions)
- Lancement et attachement de la Jconsole
- Les différentes catégories d'informations collectées
Visual GC et GC Viewer
- Les différences entre les deux outils
- Analyses poussées de l'activité du GC
Java VisualVM
- Présentation de l'outil
- Profilling de type CPU
- Profilling de typer Memory
Autres outils de profilage
- Utilisation du plugin Eclipse Memory Analyser Tool