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