Go 1.3 Garbage Collector Retention of Server Memory
Verstehen des Problems
Ein TCP-Server, der Verbindungen mit unregelmäßigem Datenverkehr verarbeitet, belegt erhebliche Mengen an Systemspeicher das wird nicht wieder an das Betriebssystem freigegeben. Dieses Verhalten wird problematisch, wenn mehrere Server auf demselben Computer ausgeführt werden, da die Speicherressourcen mit der Zeit erschöpft sein können.
Hintergrund
Gos Garbage Collector (GC) gibt ungenutzten Heap-Speicher frei, tut dies aber nicht. Der virtuelle Adressraum des Prozesses wird nicht immer verkleinert. Auf Windows-Plattformen ist dies nicht möglich. Sogar auf Unix-basierten Systemen nutzt Go einen Systemaufruf, um das Betriebssystem darüber zu informieren, dass ungenutzter Heap-Speicher zurückgewonnen werden kann. Dies dauert jedoch einige Zeit (bis zu 7 Minuten).
Analyse
Basierend auf Nach Informationen aus Go-Community-Foren kann das Problem mit den folgenden Faktoren zusammenhängen:
-
Go gibt nicht den gesamten Speicher für frei Betriebssystem: Go gibt nur Heap-Variablen frei; Goroutine-Stacks werden nicht freigegeben.
-
Verzögerte Speicherfreigabe: Speicher wird möglicherweise nicht sofort an das Betriebssystem zurückgegeben, nachdem er vom GC als frei markiert wurde. Außerdem ist ein Betriebssystem-Sweep erforderlich, der bis zu 7 Minuten dauern kann.
-
Überberichtete Speichernutzung: Nicht der gesamte zugewiesene Speicher ist „echter“ Speicher. Einige werden möglicherweise von der Laufzeit, aber nicht vom Programm verwendet, so dass die Verarbeitung dem Betriebssystem überlassen bleibt.
Mögliche Lösungen
-
Explizite Speicherfreigabe: Müll erzwingen Sammlung mit runtime.GC() und geben Sie explizit Speicher an das Betriebssystem frei runtime.FreeOSMemory.
Einschränkungen
- runtime.GC() sollte sparsam verwendet werden, da es sich auf die Leistung auswirken kann.
- runtime.FreeOSMemory funktioniert nur wenn der GC ausgeführt wurde.
- Goroutine-Stapelspeicher wird nicht vorhanden sein veröffentlicht.
Danksagungen
- Dmitri Vyukov (Go-Entwickler) lieferte wichtige Erkenntnisse zu diesem Thema.
Das obige ist der detaillierte Inhalt vonWarum gibt mein Go 1.3-Server den Speicher nicht wieder an das Betriebssystem frei?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!