Maison base de données tutoriel mysql Comment gérer le délai d'expiration de la connexion MySQL dans un programme Java ?

Comment gérer le délai d'expiration de la connexion MySQL dans un programme Java ?

Jul 01, 2023 am 10:42 AM
mysql java 连接超时

Comment gérer le délai d'expiration de la connexion MySQL dans un programme Java ?

Lorsque nous développons des applications basées sur Java, nous devons souvent interagir avec la base de données. MySQL est une base de données relationnelle couramment utilisée qui utilise le protocole TCP/IP pour établir une connexion avec les programmes Java. Cependant, en raison de l'instabilité du réseau ou pour d'autres raisons, un délai d'attente de connexion MySQL peut se produire. Cet article explique comment gérer les problèmes de délai de connexion MySQL dans les programmes Java.

Tout d'abord, nous devons comprendre la raison pour laquelle la connexion MySQL expire. Afin de protéger les ressources et le réseau, le serveur MySQL définira un délai d'expiration de connexion. Lorsqu'une connexion MySQL n'effectue aucune opération interactive pendant un certain temps, le serveur se déconnecte activement pour libérer des ressources. Ce délai d'expiration de connexion peut être défini dans le fichier de configuration du serveur MySQL et la valeur par défaut est de 8 heures.

Les méthodes suivantes peuvent être utilisées pour gérer le délai d'expiration de la connexion MySQL dans les programmes Java :

  1. Définir le délai d'expiration de la connexion : lorsque vous utilisez JDBC pour vous connecter à MySQL, vous pouvez set La méthode setLoginTimeout de l'objet Connection est utilisée pour définir le délai d'expiration de la connexion. Cette méthode accepte un paramètre entier en secondes indiquant le temps maximum d'attente pour qu'une connexion soit établie. Si la connexion échoue dans le délai spécifié, une exception SQLException est levée. Le délai d'expiration de la connexion peut être défini en fonction de besoins spécifiques. Un paramètre courant est de 30 secondes.
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class MySQLConnection {
    public static void main(String[] args) {
        String url = "jdbc:mysql://localhost:3306/mydb";
        String username = "root";
        String password = "password";

        try {
            DriverManager.setLoginTimeout(30);
            Connection connection = DriverManager.getConnection(url, username, password);
            // TODO: 连接成功后的操作
        } catch (SQLException e) {
            System.out.println("连接超时");
        }
    }
}
Copier après la connexion
  1. Utiliser le pooling de connexions : le pooling de connexions est une technologie de gestion des connexions de base de données qui peut améliorer les performances et la fiabilité des connexions de base de données. Le pool de connexions initialisera un certain nombre de connexions au démarrage du programme et placera ces connexions dans le pool de connexions. Lorsque vous devez vous connecter à MySQL, obtenez un objet de connexion disponible dans le pool de connexions, puis remettez l'objet de connexion dans le pool de connexions après utilisation. Le pool de connexions gère automatiquement l'ouverture et la fermeture des connexions, ainsi que les contrôles de validité des connexions. Si la connexion expire, le pool de connexions recréera automatiquement une connexion pour garantir la disponibilité de la connexion.

Les pools de connexions Java couramment utilisés incluent Apache Commons DBCP, C3P0 et HikariCP, etc. Ces frameworks de pool de connexions fournissent tous des options de configuration du délai d'expiration de la connexion, et vous pouvez gérer le problème du délai d'expiration de la connexion MySQL en définissant un délai d'expiration de connexion approprié.

  1. Détection de l'état de la connexion : en plus des deux méthodes ci-dessus, nous pouvons également gérer le délai d'expiration de la connexion MySQL en détectant manuellement l'état de la connexion. Vous pouvez exécuter régulièrement un morceau de code dans le programme pour détecter l'état de la connexion. Si la connexion a expiré, vous pouvez la fermer et en rouvrir une nouvelle. Cette méthode nécessite l’écriture manuelle du code pour détecter l’état de la connexion et se reconnecter, ce qui est relativement fastidieux.
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class MySQLConnection {
    public static void main(String[] args) {
        String url = "jdbc:mysql://localhost:3306/mydb";
        String username = "root";
        String password = "password";

        // 连接超时时间
        int timeout = 30; // 单位:秒

        while (true) {
            try {
                Connection connection = DriverManager.getConnection(url, username, password);
                // 检测连接是否可用
                if (!connection.isValid(timeout)) {
                    // 关闭无效连接
                    connection.close();
                    // 创建新连接
                    connection = DriverManager.getConnection(url, username, password);
                }
                // TODO: 连接成功后的操作

                // 休眠一段时间后重新检测连接
                Thread.sleep(3000); // 单位:毫秒
            } catch (SQLException e) {
                System.out.println("MySQL连接错误:" + e.getMessage());
            } catch (InterruptedException e) {
                System.out.println("线程休眠错误:" + e.getMessage());
            }
        }
    }
}
Copier après la connexion

Dans le code ci-dessus, on détecte la validité de la connexion en appelant la méthode isValid de l'objet Connection. Si la connexion n'est pas valide, fermez la connexion et créez une nouvelle connexion en appelant à nouveau la méthode DriverManager.getConnection.

Pour résumer, en définissant le délai d'expiration de la connexion, en utilisant un pool de connexions ou en détectant manuellement l'état de la connexion, le problème du délai d'expiration de la connexion MySQL peut être traité plus efficacement. En fonction des besoins et des scénarios spécifiques, nous pouvons choisir une méthode appropriée pour gérer les délais d'attente de connexion. Dans le même temps, afin de garantir les performances et la fiabilité du programme, le délai d'expiration de la connexion doit être défini de manière raisonnable et les exceptions de connexion doivent être traitées rapidement lorsque le délai de connexion expire. Cela peut efficacement éviter les exceptions du programme et la perte de données causées par les délais d'attente de connexion.

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Tags d'article chaud

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Racine carrée en Java Racine carrée en Java Aug 30, 2024 pm 04:26 PM

Racine carrée en Java

Nombre parfait en Java Nombre parfait en Java Aug 30, 2024 pm 04:28 PM

Nombre parfait en Java

Générateur de nombres aléatoires en Java Générateur de nombres aléatoires en Java Aug 30, 2024 pm 04:27 PM

Générateur de nombres aléatoires en Java

Numéro Armstrong en Java Numéro Armstrong en Java Aug 30, 2024 pm 04:26 PM

Numéro Armstrong en Java

Weka en Java Weka en Java Aug 30, 2024 pm 04:28 PM

Weka en Java

Numéro de Smith en Java Numéro de Smith en Java Aug 30, 2024 pm 04:28 PM

Numéro de Smith en Java

Comment corriger les erreurs mysql_native_password non chargé sur MySQL 8.4 Comment corriger les erreurs mysql_native_password non chargé sur MySQL 8.4 Dec 09, 2024 am 11:42 AM

Comment corriger les erreurs mysql_native_password non chargé sur MySQL 8.4

Questions d'entretien chez Java Spring Questions d'entretien chez Java Spring Aug 30, 2024 pm 04:29 PM

Questions d'entretien chez Java Spring

See all articles