mgo Go-Serverfehler: Zu viele geöffnete Dateien
Wenn ein MongoDB-Server mit mgo unter Ubuntu mit der Programmiersprache Go ausgeführt wird, ist dies möglich Es kann zu Fehlern kommen, die auf zu viele geöffnete Dateien zurückzuführen sind. Diese Fehler, wie z. B. „Akzeptanzfehler: akzeptiere TCP [::]:80: akzeptiere4: zu viele geöffnete Dateien“, treten normalerweise auf, nachdem der Server längere Zeit in Betrieb war, was darauf hinweist, dass der Server sein Limit erreicht hat Dateideskriptoren öffnen.
Fehlerursache
Der Fehler tritt auf, wenn der Server versucht, eine neue Verbindung herzustellen, aber stellt fest, dass das vom Betriebssystem vorgegebene Limit für geöffnete Dateien überschritten wurde. Dies kann auftreten, wenn Verbindungen nicht ordnungsgemäß geschlossen werden, was zu einer allmählichen Ansammlung offener Dateideskriptoren führt, die schließlich den Schwellenwert überschreiten.
Codeanalyse
Im bereitgestellten Codeausschnitt gibt es mehrere Bereiche, in denen die Handhabung von MongoDB-Sitzungen und -Verbindungen angepasst werden könnte, um das Ressourcenmanagement zu verbessern und zu verhindern Lecks:
-
Korrekte Verbindungs- und Sitzungsverwaltung: Die in der Hauptfunktion (session, _ := mgo.Dial("localhost")) initialisierte Sitzung ist keine dauerhafte Verbindung . Anstatt die Datenbankinstanz der Sitzung (Database = session.DB("mapdb")) zu speichern, ist es vorzuziehen, die Sitzung selbst zu speichern.
-
Fehlende Fehlerbehandlung: Fehlerbehandlung ist nicht offensichtlich im Code. Die Prüfung auf Fehler und deren angemessene Behandlung sind für eine robuste Fehlerbehandlung von entscheidender Bedeutung.
-
Verbindungen schließen: Es ist wichtig, Verbindungen und Sitzungen nach der Verwendung zu schließen. In der someHandler-Funktion wird eine geklonte Sitzungssitzung erfasst, diese wird jedoch nirgendwo explizit geschlossen. Durch das Hinzufügen einer defer sess.Close()-Anweisung wird sichergestellt, dass die Sitzung geschlossen wird, wenn die Funktion beendet wird.
Lösung
Um das Problem „zu viele offene Dateien“ zu beheben Fehler beheben und das Ressourcenmanagement des Codes verbessern, können folgende Anpassungen vorgenommen werden:
-
Verwenden Sie a Persistente Sitzung: Anstatt die Verbindungen jedes Mal neu aufzubauen, wenn eine Anfrage verarbeitet wird, speichern Sie eine einzelne mgo.Session-Instanz während der gesamten Lebensdauer des Servers. Initialisieren Sie die Sitzung einmal während des Startvorgangs und verwenden Sie sie, um für jede Anfrage neue Kopien oder Klone zu erhalten.
-
Fehler behandeln: Überprüfen Sie, ob beim Sitzungsaufbau, bei Datenbankvorgängen und beim Schließen von Verbindungen Fehler auftreten. Behandeln Sie Fehler entsprechend, indem Sie sie protokollieren oder entsprechende Korrekturmaßnahmen ergreifen.
-
Verbindungen und Sitzungen schließen: Stellen Sie sicher, dass MongoDB-Verbindungen und -Sitzungen nach der Verwendung geschlossen werden. Verwenden Sie Defer-Anweisungen, um sie automatisch zu schließen, wenn die entsprechende Funktion beendet wird.
Ähnliche Fragen
Weitere Einblicke in verwandte Themen finden Sie in den folgenden Ressourcen:
- mgo – Abfrageleistung scheint durchweg langsam (500–650 ms)
- Parallelität in gopkg.in/mgo .v2 (Mongo, Go)
Das obige ist der detaillierte Inhalt vonWarum gibt mein Go MongoDB-Server, der mgo verwendet, den Fehler „Zu viele geöffnete Dateien' zurück?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!