Les applications Spring Boot utilisent souvent le framework JPA-Hibernate pour faciliter les interactions avec les bases de données. Cependant, un défi courant rencontré concerne les échecs de connexion après un intervalle de temps spécifié, en particulier lorsqu'il s'agit de MySQL comme base de données sous-jacente.
Dans de tels scénarios, le journal de l'application affiche généralement un message d'erreur indiquant : "Le dernier paquet a réussi reçu du serveur il y a X millisecondes...", où X dépasse la valeur du délai d'attente configurée par le serveur.
Pour résoudre ce problème, plusieurs approches ont été suggérées, notamment l'utilisation de spring.datasource.testOnBorrow =propriétés true et spring.datasource.validationQuery. Cependant, ces méthodes sont généralement déconseillées.
La solution privilégiée consiste à mettre en œuvre la validation de la connexion tout au long de la durée de vie de l'application. Cela peut être accompli en configurant les propriétés suivantes :
Ces paramètres permettent une validation périodique des connexions lorsqu'elles sont inactives, permettant au pool de détecter et de supprimer les connexions rompues.
En raison de l'adoption par Spring Boot 2.x de HikariCP comme pool de connexions par défaut, la validation de connexion est désormais effectuée automatiquement par HikariCP lors de l'utilisation du mécanisme de validation JDBC.
Ainsi, en activant la validation et en fournissant des configurations appropriées pour la gestion des connexions, il est possible d'atténuer les erreurs de délai de connexion et de garantir des interactions de base de données fiables dans les applications Spring Boot utilisant JPA-Hibernate avec MySQL.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!