Überlegungen zur Parallelität in MongoDB mit gopkg.in/mgo.v2
Bei der Integration von MongoDB in eine Go-Webanwendung mit gopkg.in/mgo .v2 ist es wichtig, Best Practices für die Parallelität zu berücksichtigen, um eine optimale Leistung und Ressourcennutzung zu gewährleisten. In diesem Artikel geht es um die folgende Frage:
Kann eine einzelne mgo.Session gleichzeitig in einer Webanwendung verwendet werden, beispielsweise in einem http.Handler, oder sollten dazu Session.Copy und Session.Close verwendet werden? Stattdessen einen Pool von Sitzungen erstellen?
Erklärung:
Die mgo.Session ist im Gegensatz zu anfänglichen Annahmen tatsächlich sicher für die gleichzeitige Verwendung. In der offiziellen Dokumentation heißt es: „Alle Session-Methoden sind nebenläufigkeitssicher und können von mehreren Goroutinen aufgerufen werden.“
Dies bedeutet jedoch nicht, dass die Verwendung nur einer mgo.Session in einer gleichzeitigen Umgebung von Vorteil ist. Sitzungen verwalten automatisch einen Pool von Verbindungen, aber die Verwendung einer einzelnen Sitzung schränkt die Möglichkeit ein, mehrere Verbindungen gleichzeitig zu nutzen und möglicherweise auf Serverknoten zu verteilen, sofern verfügbar.
Erstellen neuer Sitzungen für jede Anfrage, Kopieren dieser bei Bedarf und Schließen Wenn Sie sie ordnungsgemäß ausführen (mithilfe von Session.Close mit Verzögerung), wird eine optimale Ressourcennutzung ermöglicht. Durch die Verwaltung mehrerer Verbindungen kann das System potenziell mehr Verbindungen und Serverknoten gleichzeitig nutzen, was zu schnelleren Reaktionszeiten sowohl für die Datenbank als auch für Endbenutzer führt.
Session.Close beendet nicht die zugrunde liegende Verbindung zum Server, sondern Stattdessen wird es an den Pool zurückgegeben, sodass es für andere Sitzungen verfügbar ist.
Weitere Einblicke finden Sie in der entsprechenden Diskussion zur Leistung von Sitzungen: mgo – die Abfrageleistung scheint durchweg langsam zu sein (500-650 ms).
Das obige ist der detaillierte Inhalt vonReicht eine einzelne mgo.Session für die gleichzeitige Verwendung in einer Go-Webanwendung aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!