lundi 29 décembre 2025

Migration d’une application Spring Boot 2.2 vers Spring Boot 4.0 : retour d’expérience concret

 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 vers jakarta.*

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 DISTINCT cô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

Migration d’une application Spring Boot 2.2 vers Spring Boot 4.0 : retour d’expérience concret

 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 Boots...