Erreur du serveur mgo Go : trop de fichiers ouverts
Lors de l'exécution d'un serveur MongoDB utilisant mgo sur Ubuntu avec le langage de programmation Go, c'est possible rencontrer des erreurs liées à un trop grand nombre de fichiers ouverts. Ces erreurs, telles que « Accept error: accept tcp [::]:80: accept4: too many open files », apparaissent généralement après que le serveur a fonctionné pendant une période de temps significative, indiquant que le serveur a atteint sa limite pour ouvrez les descripteurs de fichiers.
Cause de l'erreur
L'erreur se produit lorsque le serveur tente d'établir une nouvelle connexion, mais constate qu'elle a dépassé la limite imposée par le système d'exploitation pour les fichiers ouverts. Cela peut se produire si les connexions ne sont pas fermées correctement, entraînant une accumulation progressive de descripteurs de fichiers ouverts qui finissent par dépasser le seuil.
Analyse du code
Dans l'extrait de code fourni , il existe plusieurs domaines dans lesquels la gestion des sessions et des connexions MongoDB pourrait être ajustée pour améliorer la gestion des ressources et éviter fuites :
-
Connexion appropriée et gestion de session : La session initialisée dans la fonction principale (session, _ := mgo.Dial("localhost")) n'est pas une connexion persistante . Au lieu de stocker l'instance de base de données de la session (Database = session.DB("mapdb")), il est préférable de stocker la session elle-même.
-
Manque de gestion des erreurs : La gestion des erreurs n'est pas évidente dans le code. Vérifier les erreurs et les gérer de manière appropriée est crucial pour une gestion robuste des erreurs.
-
Fermeture des connexions : Il est essentiel de fermer les connexions et les sessions après utilisation. Dans la fonction someHandler, une session de session clonée est acquise, mais elle n'est explicitement fermée nulle part. L'ajout d'une instruction defer sess.Close() garantit que la session est fermée lorsque la fonction se termine.
Solution
Pour résoudre le "trop de fichiers ouverts" erreur et améliorer la gestion des ressources du code, les ajustements suivants peuvent être effectués :
-
Utiliser un persistant Session : Au lieu de rétablir les connexions à chaque fois qu'une requête est traitée, stockez une seule instance mgo.Session pendant toute la durée de vie du serveur. Initialisez la session une fois au démarrage et utilisez-la pour acquérir de nouvelles copies ou clones pour chaque demande.
-
Gérer les erreurs : recherchez les erreurs lors de l'établissement de la session, des opérations de base de données et de la fermeture des connexions. Gérez les erreurs en conséquence en enregistrant ou en prenant les mesures correctives appropriées.
-
Fermer les connexions et les sessions : assurez-vous que les connexions et les sessions MongoDB sont fermées après utilisation. Utilisez les instructions defer pour les fermer automatiquement lorsque la fonction concernée se termine.
Questions connexes
Pour plus d'informations sur des sujets connexes, reportez-vous aux ressources suivantes :
- mgo - les performances des requêtes semblent constamment lentes (500-650 ms)
- Concurrence concurrente dans gopkg.in/mgo .v2 (Mongo, vas-y)
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!