Maison  >  Article  >  développement back-end  >  Pratique de la programmation simultanée Golang : compétences de surveillance et de débogage des Goroutines

Pratique de la programmation simultanée Golang : compétences de surveillance et de débogage des Goroutines

王林
王林original
2023-07-19 14:09:181534parcourir

Pratique de programmation simultanée Golang : compétences de surveillance et de débogage des Goroutines

Introduction :
Avec l'amélioration continue de la puissance de traitement informatique et la popularité des processeurs multicœurs, la programmation simultanée est devenue une fonctionnalité importante dans les langages de programmation modernes. En tant que langage de programmation prenant en charge la concurrence, le mécanisme Goroutines et Channels intégré de Golang rend la programmation simultanée très simple et efficace. Cependant, la programmation simultanée est également confrontée à certains défis, tels que la manière de surveiller et de déboguer l'état d'exécution et le comportement des Goroutines. Dans cet article, nous présenterons quelques conseils et outils pratiques pour surveiller et déboguer les Goroutines dans Golang, et les démontrerons avec des exemples de code.

1. Méthode de surveillance des Goroutines

  1. Utilisez les fonctions du package d'exécution

Dans Golang, vous pouvez utiliser les fonctions du package d'exécution pour surveiller et obtenir des informations associées aux Goroutines, telles que :

  • runtime. NumGoroutine() : obtenez le nombre de Goroutines dans le système actuel
  • runtime.Gosched() : abandonnez activement le processeur et laissez les autres Goroutines s'exécuter
  • runtime.GOMAXPROCS() : définissez le nombre maximum de processeurs exécutés simultanément

Voici un exemple de code qui montre comment utiliser la fonction du package d'exécution pour surveiller l'état d'exécution des Goroutines :

package main

import (
    "fmt"
    "runtime"
)

func main() {
    go func() {
        for {
            fmt.Println("Hello Goroutine")
        }
    }()

    fmt.Println("Number of Goroutines:", runtime.NumGoroutine())

    // 主动让出CPU
    runtime.Gosched()

    fmt.Println("End of program")
}

Exécutez le code ci-dessus, vous pouvez voir que le résultat de sortie affichera le nombre de Goroutines dans le système actuel.

  1. Utilisez le package pprof pour l'analyse des performances

Golang fournit le package pprof, qui peut facilement effectuer une analyse des performances, y compris la surveillance du fonctionnement des Goroutines. En activant le service pprof, l'état et les statistiques des Goroutines peuvent être consultés en temps réel dans le navigateur.

Ce qui suit est un exemple de code qui montre comment utiliser le package pprof pour surveiller l'état d'exécution des Goroutines :

package main

import (
    "fmt"
    "net/http"
    _ "net/http/pprof"
)

func main() {
    go func() {
        for {
            fmt.Println("Hello Goroutine")
        }
    }()

    // 启用pprof服务
    go func() {
        http.ListenAndServe("localhost:6060", nil)
    }()

    select {}
}

Dans le code, nous activons le service pprof et accédons http://localhost:6060/debug/pprof/goroutine?debug=1 via le navigateur pour afficher les informations détaillées des Goroutines.

2. Méthode de débogage des Goroutines

  1. Utiliser le débogueur GDB

Golang fournit une prise en charge relativement simple pour le débogage. Vous pouvez utiliser le débogueur GDB pour déboguer les Goroutines.

Tout d'abord, nous devons créer un binaire déboguable et activer le mode débogage :

$ go build -gcflags "-N -l"

Ensuite, utiliser GDB pour déboguer :

$ gdb ./your-program
(gdb) break main.main // 设置断点
(gdb) run
(gdb) goroutines // 查看Goroutines信息
(gdb) goroutine n // 切换到第n个Goroutine
(gdb) list // 显示当前Goroutine的代码
(gdb) info locals // 显示当前Goroutine的局部变量
(gdb) info frame // 显示当前Goroutine的栈帧
(gdb) continue // 继续运行

Grâce au débogueur GDB, nous pouvons facilement visualiser, déboguer et suivre le fonctionnement des Goroutines.

  1. Utilisez le débogueur Delve

En plus de GDB, il existe également un outil de débogage très populaire appelé Delve, qui fournit une interface de débogage plus conviviale et des fonctions de débogage plus puissantes.

Tout d'abord, nous devons installer Delve :

$ go get -u github.com/go-delve/delve/cmd/dlv

Ensuite, utilisez Delve pour déboguer les Goroutines :

$ dlv debug ./your-program
(dlv) break main.main // 设置断点
(dlv) run
(dlv) goroutines // 查看Goroutines信息
(dlv) goroutine n // 切换到第n个Goroutine
(dlv) list // 显示当前Goroutine的代码
(dlv) locals // 显示当前Goroutine的局部变量
(dlv) frame // 显示当前Goroutine的栈帧
(dlv) continue // 继续运行

Grâce au débogueur Delve, nous pouvons déboguer et tracer les Goroutines plus facilement.

Résumé :
Grâce à certaines techniques de surveillance et de débogage présentées dans cet article, nous pouvons avoir une compréhension et une maîtrise plus approfondies de l'état d'exécution et du comportement des Goroutines. Ces techniques et outils sont très utiles pour localiser les problèmes, améliorer les performances du programme et optimiser l'architecture de concurrence. Dans le développement réel, nous devons choisir des méthodes appropriées pour surveiller et déboguer les Goroutines en fonction de situations spécifiques afin d'améliorer la stabilité du programme et l'efficacité opérationnelle.

Références :

  • https://golang.org/pkg/runtime/
  • https://golang.org/pkg/net/http/pprof/
  • https://github.com/go- delve /fouiller

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn