En 2019, nous avons développé une application métier basée sur :
- Java 8
- Spring Boot 2.2.7
- Gradle 6.6.1
- Thymeleaf
- Bootstrap 4.3.1
- Environ 40 000 lignes de code Java
Fin 2025, voici un retour d’expérience concret sur la migration vers :
- Java 25
- Spring Boot 4.0.1
- Gradle 9.2.1
La partie thymeleaf, n'a pas été touché, il y a quelques warning concernant l'obsolescence de certain commande tel que th:include.
Une migration plus rapide que prévu
Un point important : en moins de 30 minutes, l’application démarrait sur la nouvelle stack.
Évidemment, "ça démarre" ne veut pas dire "tout fonctionne", mais ce premier jalon est très révélateur :
- la base Spring Boot reste solide
- les outils de migration sont matures
- la dette technique était maîtrisée
Les changements majeurs rencontrés
De javax.* à jakarta.*
C’est probablement le changement le plus visible.
- Tous les imports
javax.*doivent être migrés versjakarta.*
Impact sur :
- JPA
- Validation
- Servlet API
- Sécurité
Rien de compliqué, mais beaucoup de petites modifications réparties dans le code.
Hibernate : requêtes et comportements modifiés
C’est ici que se trouvent les changements les plus subtils.
Le QueryHint hint_pass_distinct_through ne fonctionne plus
Certaines optimisations Hibernate basées sur ce hint ne sont plus supportées ou ont changé de comportement.
Résultat :
-
des requêtes qui fonctionnaient avant produisent maintenant des résultats différents
-
nécessité de revoir certaines stratégies de
DISTINCTcôté JPQL ou Criteria
Séquences de base de données
Certaines séquences ont dû être modifiées :
-
stratégies de génération (
allocationSize,sequenceName) -
compatibilité avec les nouvelles versions Hibernate
-
comportement différent selon le dialecte
Ce point est critique sur des applications avec beaucoup d’écritures en base.
Pour avoir effectuer énormément de migration de spring boot, je dirais que souvent c'est dans les requêtes que souvent qu'il y a des problèmes. Hibernate change beaucoup, une rêquetes qui passait ne fonctionne pu... mais fonctionne pourtant encore avec d'autre ORM. Maintenant j'évite d'écrire des requêtes dynamiques en employant les Specification ou JPQL. Je préfère opter pour du natif.
Dépréciations : beaucoup de nettoyage
La migration a mis en lumière :
- un grand nombre d’API : jpa, sécurité dépréciées
- des patterns devenus obsolètes
Résultat positif : un code plus propre, plus explicite et plus aligné avec les standards actuels.
Bilan global
Migration faisable sur une base de code de petite taille en moins d'une journée.
Temps de démarrage rapide, même avant corrections
Écosystème Spring mature malgré les changements majeurs
Convention over configuration a permis de diminuer le temps de migration.
Effort réel sur :
- Hibernate
- JPA Criteria / Specifications
- Sécurité
- Jakarta
Aucun commentaire:
Enregistrer un commentaire