


Réutilisation d'une connexion à une base de données PostgreSQL pour les insertions de lignes dans Go
Problème
Dans un programme Go, tentative d'insertion de données dans une table PostgreSQL à l'aide d'un une connexion à une seule base de données pour chaque message reçu de RabbitMQ a entraîné une erreur due au dépassement du nombre maximum de connexions.
Solution
Le problème réside dans la façon dont les requêtes SQL sont exécutées dans Go. sql.DB est un pool de connexions plutôt qu'une connexion unique. Il ouvre les connexions selon les besoins et réutilise les connexions inactives, mais dans ce cas, les connexions n'étaient pas libérées correctement.
Le problème survient lors de l'utilisation de db.QueryRow sans appeler Scan sur la valeur *Row renvoyée. *Row contient une référence à une connexion, qui est automatiquement libérée lorsque Scan est appelé. Cependant, dans le code fourni, Scan n'était pas appelé, ce qui entraînait l'accumulation des connexions dans le pool de connexions.
Pour résoudre ce problème, la solution consiste soit à utiliser db.Exec si la sortie n'est pas requise, ou pour appeler Scan sur la valeur *Row renvoyée par db.QueryRow.
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!

GoroutinesaConctionnement est en train de savoir-faire, en permettant à la croissance de la pondération.1).

La poursuite de la théorie des fonctionnalités, les réglementations de configurations, l'orperformance a été utile, utilise-to-nection des fonctionnalités.

GoInterfaceSareMethodsignatisesetSeTyPesmustimplement, permettant de permettre à la transfert depolymorphisms avec une information pour laCleaner, modularCode.Eplicite Implicitement satisfait, utile pour lesquelleserrorSandDeCoupling, ButrequireCarefusetoavoidRumeerRorroSedMaintAntainTaidTaipTyPesafety.

Utilisez la fonction Recover () dans GO pour récupérer de la panique. Les méthodes spécifiques sont: 1) Utiliser Recover () pour capturer la panique dans la fonction de différence pour éviter les accidents du programme; 2) Enregistrer les informations d'erreur détaillées pour le débogage; 3) Décidez de reprendre l'opportunité de reprendre l'exécution du programme en fonction de la situation spécifique; 4) Utiliser avec prudence pour éviter d'affecter les performances.

L'article discute de l'utilisation du package "Strings" de Go pour la manipulation des chaînes, détaillant les fonctions communes et les meilleures pratiques pour améliorer l'efficacité et gérer efficacement Unicode.

L'article détaille en utilisant le package "crypto" de Go pour les opérations cryptographiques, discutant de la génération de clés, de la gestion et des meilleures pratiques pour la mise en œuvre sécurisée. Counomage de Character: 159

L'article détaille l'utilisation du package "Time" de Go pour gérer les dates, les heures et les fuseaux horaires, y compris l'heure actuelle, la création de temps spécifiques, l'analyse des chaînes et la mesure du temps écoulé.

L'article discute de l'utilisation du package "Reflect" de Go pour l'inspection et la modification des variables, mettant en évidence les méthodes et les considérations de performances.


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

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

Dreamweaver CS6
Outils de développement Web visuel

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

Télécharger la version Mac de l'éditeur Atom
L'éditeur open source le plus populaire

VSCode Windows 64 bits Télécharger
Un éditeur IDE gratuit et puissant lancé par Microsoft
