Heim > Backend-Entwicklung > Golang > Golang-Planungseinstellungen

Golang-Planungseinstellungen

WBOY
Freigeben: 2023-05-19 09:18:30
Original
513 Leute haben es durchsucht

Golang ist eine effiziente und benutzerfreundliche Programmiersprache, und ihr Planungsmechanismus ist einer der wichtigen Faktoren für ihre hervorragende Leistung. In Golang steuert der Scheduler alle Goroutinen als leichtgewichtige Threads der Go-Sprache. Jede Goroutine kann unabhängig ausgeführt werden, um eine hohe Parallelität zu erreichen. Um die Leistung von Golang optimal nutzen zu können, müssen wir die Planungseinstellungen optimieren. In diesem Artikel wird erläutert, wie der Planungsmechanismus von Golang eingerichtet wird.

Golangs Scheduler basiert auf dem M:N-Modell. Normalerweise entspricht ein Betriebssystem-Thread (M) mehreren Goroutinen (N). Der Scheduler weist Goroutinen den verfügbaren Threads zu, um eine gleichzeitige Ausführung zu erreichen. Der Planer plant Aufgaben entsprechend dem Status jeder Goroutine, um eine optimale Nutzung der Computerressourcen sicherzustellen.

Parameter, die Sie beim Einrichten des Golang-Schedulers kennen müssen

Bevor Sie den Golang-Scheduler einrichten, müssen Sie die folgenden Parameter kennen:

  1. GOMAXPROCS

GOMAXPROCS ist ein Parameter, der zum Festlegen der maximalen Anzahl von CPUs verwendet wird, die verwendet werden können von Golang-Programmen. Standardmäßig ist der Wert von GOMAXPROCS die Anzahl der CPU-Kerne der Maschine. Wenn Sie diesen Parameter zu groß oder zu klein einstellen, wirkt sich dies auf die Leistung von Golang aus.

Wenn GOMAXPROCS zu groß eingestellt ist, erhöht sich die Anzahl der Threads, was dazu führt, dass die CPU häufig zwischen verschiedenen Threads wechselt, was zu einer erhöhten Systemlast führt und sogar die Effizienz der Anwendungsausführung beeinträchtigt.

Wenn GOMAXPROCS zu klein eingestellt ist, kann das Programm andererseits die Leistung der Multi-Core-CPU nicht vollständig nutzen, da Golangs Scheduler auf präemptivem Scheduling basiert, wenn GOMAXPROCS eingestellt ist Zu klein, Goroutine kann nicht rechtzeitig geplant werden, was zu einer Goroutine-Blockierung und einer geringen Effizienz der Programmausführung führt.

  1. GOGC

GOGC ist ein Parameter, der zur Steuerung der Auslösezeit und -häufigkeit der Garbage Collection von Golang verwendet wird. Der Garbage Collector von Golang basiert auf dem Mark-and-Sweep-Algorithmus, was bedeutet, dass das Programm während des Betriebs für die Garbage Collection eine gewisse Zeit anhalten muss. Der Standardwert von GOGC ist 100. Das heißt, wenn die Heap-Speichernutzung im System 100 % des Gesamtspeichers erreicht, wird die Speicherbereinigung ausgelöst.

Wenn GOGC zu niedrig eingestellt ist, führt dies dazu, dass das System häufig eine Speicherbereinigung durchführt, was zu einer Verringerung der Effizienz der Programmausführung führt. Wenn GOGC zu hoch eingestellt ist, dauert es lange, bis der Garbage Collector ausgelöst wird, was sich auf die Speichernutzungseffizienz des Programms auswirkt.

  1. GoSchedTimeout

GoSchedTimeout ist ein Parameter, der zum Festlegen des Planungsintervalls von Goroutine verwendet wird. Standardmäßig basiert die Goroutine-Planung auf dem Wettbewerb um Computerressourcen und nicht auf der Aufgabenplanung nach einem vorgegebenen Zeitplan.

Wenn GoSchedTimeout auf einen sehr kleinen Wert eingestellt ist, führt dies dazu, dass Goroutine häufig geplant wird, wodurch die Ausführungseffizienz des Programms verringert wird. Wenn GoSchedTimeout hingegen auf einen zu großen Wert eingestellt ist, wird Goroutine nicht rechtzeitig geplant, was sich auf die Ausführungseffizienz des Programms auswirkt.

  1. MaxBackgroundGC

MaxBackgroundGC ist ein Parameter, der zum Festlegen der maximalen Anzahl gleichzeitiger Garbage Collections in Golang verwendet wird. Der Garbage-Collection-Mechanismus von Golang wird standardmäßig im Hintergrund ausgeführt. MaxBackgroundGC wird verwendet, um den Anteil der gleichzeitigen Garbage Collection festzulegen. Der Standardwert dieses Werts ist 1, d. h. wenn derzeit 5 CPU-Kerne vorhanden sind, kann maximal eine Garbage Collection-Aufgabe parallel im Hintergrund ausgeführt werden zur gleichen Zeit.

Wenn MaxBackgroundGC zu groß eingestellt ist, führt dies zu einer übermäßigen Nutzung der Systemressourcen und beeinträchtigt die Ausführungseffizienz des Programms. Wenn MaxBackgroundGC zu klein eingestellt ist, beeinträchtigt dies die Effizienz der Speicherbereinigung.

Stellen Sie die Optimierung des Golang-Planungsmechanismus ein. Dieser Parameter kann beim Programmstart festgelegt werden:

import "runtime"
func main() {
    runtime.GOMAXPROCS(8)
    //...
}
Nach dem Login kopieren

Set GOGC
  1. Wenn das Programm initialisiert wird, können Sie die Häufigkeit und den Zeitpunkt der Speicherbereinigung steuern, indem Sie den Wert von GOGC festlegen:
import (
    "runtime"
    "time"
)
func main() {
    runtime.GC()
    //设置触发时机
    runtime.SetGCPercent(10)
    //设置触发时机和时间
    debug.SetGCPercent(20)
    debug.SetGCPercent(-1)
    //...
}
Nach dem Login kopieren

Set GoSchedTimeout
  1. Golang Der Scheduler ist standardmäßig asynchron und bestimmt basierend auf der CPU-Konkurrenz, wann Goroutine geplant wird. Daher ist der Standardwert von GoSchedTimeout relativ groß eingestellt. Wenn Sie ihn anpassen müssen, können Sie ihn im Programm festlegen:
runtime.Gosched()
Nach dem Login kopieren

Führen Sie GC regelmäßig aus
  1. Da der Garbage-Collection-Mechanismus von Golang auf dem Mark-Sweep-Algorithmus basiert Während der Speicherbereinigung muss die Ausführung des Programms angehalten werden, was sich auf die Ausführungseffizienz des Programms auswirkt. Daher können Sie die Auswirkungen einer über einen längeren Zeitraum durchgeführten Garbage Collection vermeiden, indem Sie den GC regelmäßig ausführen. Im Programm können Sie es so einstellen:
func gc() {
        for {
              select {
              case <-time.After(time.Minute):
                   runtime.GC()
              }
        }
}
Nach dem Login kopieren

Zusammenfassung

    Golang ist eine Hochleistungsprogrammiersprache und ihr Parallelitätsmechanismus ist einer der wichtigen Faktoren für ihre hervorragende Leistung. In diesem Artikel erfahren Sie, wie Sie den Planungsmechanismus von Golang einrichten, einschließlich der Einstellung von Parametern wie GOMAXPROCS, GOGC, GoSchedTimeout und MaxBackgroundGC. Durch eine angemessene Einstellung dieser Parameter kann die Leistung von Golang voll ausgenutzt und die Ausführungseffizienz des Programms verbessert werden.

Das obige ist der detaillierte Inhalt vonGolang-Planungseinstellungen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage