recherche
Maisondéveloppement back-endGolangMaîtriser le modèle Nursery de Go : améliorez l'efficacité et la robustesse de votre code simultané

Mastering Go

Les goroutines et la concurrence structurée changent la donne dans la programmation Go. Ils offrent des moyens puissants de gérer les opérations simultanées, rendant notre code plus efficace et plus robuste. Explorons le modèle Nursery, une technique qui met de l'ordre dans le chaos de la programmation simultanée.

Le modèle Nursery consiste à créer des groupes organisés de tâches. Cela nous donne un meilleur contrôle sur le comportement de nos goroutines et nous aide à gérer les erreurs avec plus de grâce. Considérez-le comme un moyen de garder notre code concurrent bien rangé et gérable.

Pour mettre en œuvre le modèle Nursery, nous commençons par créer un contexte parent qui supervise un groupe de goroutines enfants. Ce contexte parent peut annuler tous ses enfants si quelque chose ne va pas, garantissant ainsi que nous ne laissons aucun fil de discussion en suspens.

Voici un exemple de base de la façon dont nous pourrions mettre en œuvre une crèche simple :

type Nursery struct {
    wg   sync.WaitGroup
    ctx  context.Context
    cancel context.CancelFunc
}

func NewNursery() (*Nursery, context.Context) {
    ctx, cancel := context.WithCancel(context.Background())
    return &Nursery{
        ctx:    ctx,
        cancel: cancel,
    }, ctx
}

func (n *Nursery) Go(f func() error) {
    n.wg.Add(1)
    go func() {
        defer n.wg.Done()
        if err := f(); err != nil {
            n.cancel()
        }
    }()
}

func (n *Nursery) Wait() {
    n.wg.Wait()
}

Cette pépinière nous permet de générer plusieurs goroutines et d'attendre qu'elles soient toutes terminées. Si l'un d'entre eux renvoie une erreur, la crèche annule toutes les autres goroutines.

L'un des principaux avantages du modèle Nursery est la façon dont il gère les paniques. Dans Go, une panique dans une goroutine n'arrête pas automatiquement les autres goroutines. Cela peut entraîner des fuites de ressources et un état incohérent. Avec une pépinière, nous pouvons attraper la panique et nous assurer que toutes les goroutines associées sont correctement arrêtées.

Améliorons notre crèche pour gérer les paniques :

func (n *Nursery) Go(f func() error) {
    n.wg.Add(1)
    go func() {
        defer n.wg.Done()
        defer func() {
            if r := recover(); r != nil {
                fmt.Println("Recovered from panic:", r)
                n.cancel()
            }
        }()
        if err := f(); err != nil {
            n.cancel()
        }
    }()
}

Maintenant, si une goroutine panique, nous l'attraperons, l'enregistrerons et annulerons toutes les autres goroutines de la crèche.

Un autre aspect crucial du modèle Nursery est la gestion des ressources. Dans les systèmes distribués, nous devons souvent coordonner plusieurs opérations qui utilisent des ressources partagées. La crèche peut contribuer à garantir que ces ressources sont correctement acquises et libérées.

Voici un exemple de la façon dont nous pourrions utiliser une pépinière pour gérer les connexions à la base de données :

func main() {
    nursery, ctx := NewNursery()
    defer nursery.Wait()

    dbPool := createDBPool(ctx)
    defer dbPool.Close()

    nursery.Go(func() error {
        return processOrders(ctx, dbPool)
    })

    nursery.Go(func() error {
        return updateInventory(ctx, dbPool)
    })

    nursery.Go(func() error {
        return sendNotifications(ctx, dbPool)
    })
}

Dans cet exemple, nous créons un pool de connexions à la base de données et le transmettons à plusieurs opérations simultanées. La pépinière garantit que si une opération échoue, toutes les autres sont annulées et le pool de bases de données est correctement fermé.

Le modèle Nursery brille vraiment lorsque nous devons limiter la concurrence. Dans de nombreux scénarios réels, nous souhaitons exécuter plusieurs opérations simultanément, mais pas toutes en même temps. Nous pouvons modifier notre pépinière pour inclure un sémaphore qui limite le nombre d'opérations simultanées :

type Nursery struct {
    wg       sync.WaitGroup
    ctx      context.Context
    cancel   context.CancelFunc
    semaphore chan struct{}
}

func NewNursery(maxConcurrency int) (*Nursery, context.Context) {
    ctx, cancel := context.WithCancel(context.Background())
    return &Nursery{
        ctx:      ctx,
        cancel:   cancel,
        semaphore: make(chan struct{}, maxConcurrency),
    }, ctx
}

func (n *Nursery) Go(f func() error) {
    n.wg.Add(1)
    go func() {
        n.semaphore 



Cette implémentation garantit que pas plus de goroutines maxConcurrency ne s'exécutent simultanément, évitant ainsi l'épuisement des ressources.

Les délais d'attente sont un autre aspect critique de la programmation simultanée, en particulier dans les systèmes distribués. Nous pouvons facilement ajouter une fonctionnalité de délai d'attente à notre pépinière :

type Nursery struct {
    wg   sync.WaitGroup
    ctx  context.Context
    cancel context.CancelFunc
}

func NewNursery() (*Nursery, context.Context) {
    ctx, cancel := context.WithCancel(context.Background())
    return &Nursery{
        ctx:    ctx,
        cancel: cancel,
    }, ctx
}

func (n *Nursery) Go(f func() error) {
    n.wg.Add(1)
    go func() {
        defer n.wg.Done()
        if err := f(); err != nil {
            n.cancel()
        }
    }()
}

func (n *Nursery) Wait() {
    n.wg.Wait()
}

Cette méthode nous permet de définir un délai d'attente pour chaque opération. Si l'opération ne se termine pas dans le délai imparti, elle est annulée, et toutes les autres opérations en crèche sont également annulées.

Le modèle Nursery devient particulièrement puissant lorsqu'il s'agit de dépendances complexes entre goroutines. Dans de nombreux scénarios réels, certaines opérations dépendent des résultats d’autres. Nous pouvons étendre notre pépinière pour gérer ces dépendances :

func (n *Nursery) Go(f func() error) {
    n.wg.Add(1)
    go func() {
        defer n.wg.Done()
        defer func() {
            if r := recover(); r != nil {
                fmt.Println("Recovered from panic:", r)
                n.cancel()
            }
        }()
        if err := f(); err != nil {
            n.cancel()
        }
    }()
}

Cela nous permet de définir des tâches avec des dépendances, en garantissant qu'elles s'exécutent dans le bon ordre tout en bénéficiant de la concurrence lorsque cela est possible.

Le modèle Nursery ne consiste pas seulement à gérer des goroutines ; il s'agit de créer un code concurrent plus maintenable et plus robuste. En fournissant un moyen structuré de gérer la concurrence, cela nous aide à éviter les pièges courants tels que les fuites de goroutines et les conditions de concurrence.

Dans les microservices et les applications à grande échelle, le modèle Nursery peut changer la donne. Cela nous permet de diviser les flux de travail complexes en unités gérables et annulables. Ceci est particulièrement utile lorsqu'il s'agit de transactions distribuées ou de processus métier complexes qui s'étendent sur plusieurs services.

Voici un exemple de la façon dont nous pourrions utiliser le modèle Nursery dans une architecture de microservice :

func main() {
    nursery, ctx := NewNursery()
    defer nursery.Wait()

    dbPool := createDBPool(ctx)
    defer dbPool.Close()

    nursery.Go(func() error {
        return processOrders(ctx, dbPool)
    })

    nursery.Go(func() error {
        return updateInventory(ctx, dbPool)
    })

    nursery.Go(func() error {
        return sendNotifications(ctx, dbPool)
    })
}

Dans cet exemple, nous traitons une commande en utilisant plusieurs opérations simultanées. Nous mettons à jour l'inventaire, traitons le paiement et expédions la commande simultanément. Nous avons également une goroutine qui attend la fin de toutes ces opérations avant d'envoyer un email de confirmation. Si une opération échoue ou expire, toutes les autres sont annulées.

Le modèle Nursery brille également en matière de gestion des erreurs dans le code concurrent. La gestion traditionnelle des erreurs peut devenir complexe lorsqu’il s’agit de plusieurs goroutines. La crèche offre un moyen centralisé de gérer les erreurs :

type Nursery struct {
    wg       sync.WaitGroup
    ctx      context.Context
    cancel   context.CancelFunc
    semaphore chan struct{}
}

func NewNursery(maxConcurrency int) (*Nursery, context.Context) {
    ctx, cancel := context.WithCancel(context.Background())
    return &Nursery{
        ctx:      ctx,
        cancel:   cancel,
        semaphore: make(chan struct{}, maxConcurrency),
    }, ctx
}

func (n *Nursery) Go(f func() error) {
    n.wg.Add(1)
    go func() {
        n.semaphore 



<p>Cette implémentation collecte toutes les erreurs qui se produisent dans les goroutines de la crèche. Lorsque nous appelons Wait(), il renvoie une seule erreur qui encapsule toutes les erreurs individuelles.</p>

<p>Le modèle Nursery ne concerne pas seulement la gestion des goroutines ; il s'agit de créer des systèmes plus résilients. En fournissant une manière structurée de gérer la simultanéité, il nous aide à créer des applications capables de gérer avec élégance les échecs et les situations inattendues.</p>

<p>En conclusion, le pattern Nursery est un outil puissant pour gérer la concurrence dans Go. Il fournit une approche structurée pour générer et gérer des goroutines, gérer les erreurs et les paniques et coordonner des flux de travail complexes. En implémentant ce modèle, nous pouvons créer un code concurrent plus robuste, maintenable et efficace, en particulier dans les applications à grande échelle et les architectures de microservices. À mesure que nous continuons à construire des systèmes distribués plus complexes, des modèles comme celui-ci deviendront de plus en plus importants dans notre boîte à outils de programmation Go.</p>


<hr>

<h2>
  
  
  Nos créations
</h2>

<p>N'oubliez pas de consulter nos créations :</p><p><strong>Centre des investisseurs</strong> | <strong>Vie intelligente</strong> | <strong>Époques & Échos</strong> | <strong>Mystères déroutants</strong> | <strong>Hindutva</strong> | <strong>Développeur Élite</strong> | <strong>Écoles JS</strong></p>


<hr>

<h3>
  
  
  Nous sommes sur Medium
</h3>

<p><strong>Tech Koala Insights</strong> | <strong>Epoques & Echos Monde</strong> | <strong>Support Central des Investisseurs</strong> | <strong>Mystères déroutants Medium</strong> | <strong>Sciences & Epoques Medium</strong> | <strong>Hindutva moderne</strong></p>


          

            
        

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
Golang: le langage de programmation Go expliquéGolang: le langage de programmation Go expliquéApr 10, 2025 am 11:18 AM

Les caractéristiques principales de GO incluent la collection de déchets, la liaison statique et le support de concurrence. 1. Le modèle de concurrence du langage GO réalise une programmation concurrente efficace via le goroutine et le canal. 2. Les interfaces et les polymorphismes sont implémentés via des méthodes d'interface, de sorte que différents types peuvent être traités de manière unifiée. 3. L'utilisation de base démontre l'efficacité de la définition et de l'appel des fonctions. 4. Dans une utilisation avancée, les tranches offrent des fonctions puissantes de redimensionnement dynamique. 5. Des erreurs courantes telles que les conditions de course peuvent être détectées et résolues par l'imagerie. 6. Optimisation des performances Réutiliser les objets via Sync.Pool pour réduire la pression de collecte des ordures.

Objectif de Golang: Construire des systèmes efficaces et évolutifsObjectif de Golang: Construire des systèmes efficaces et évolutifsApr 09, 2025 pm 05:17 PM

GO Language fonctionne bien dans la construction de systèmes efficaces et évolutifs. Ses avantages incluent: 1. Haute performance: compilé en code machine, vitesse de course rapide; 2. Programmation simultanée: simplifier le multitâche via les goroutines et les canaux; 3. Simplicité: syntaxe concise, réduction des coûts d'apprentissage et de maintenance; 4. Plate-forme multipliée: prend en charge la compilation multiplateforme, déploiement facile.

Pourquoi les résultats d'ordre par des déclarations dans le tri SQL semblent-ils parfois aléatoires?Pourquoi les résultats d'ordre par des déclarations dans le tri SQL semblent-ils parfois aléatoires?Apr 02, 2025 pm 05:24 PM

Confus quant au tri des résultats de la requête SQL. Dans le processus d'apprentissage de SQL, vous rencontrez souvent des problèmes déroutants. Récemment, l'auteur lit "Mick-SQL Basics" ...

La convergence de la pile technologique est-elle juste un processus de sélection de la pile technologique?La convergence de la pile technologique est-elle juste un processus de sélection de la pile technologique?Apr 02, 2025 pm 05:21 PM

La relation entre la convergence des piles technologiques et la sélection de la technologie dans le développement de logiciels, la sélection et la gestion des piles technologiques sont un problème très critique. Récemment, certains lecteurs ont proposé ...

Comment utiliser la comparaison de la réflexion et gérer les différences entre trois structures en Go?Comment utiliser la comparaison de la réflexion et gérer les différences entre trois structures en Go?Apr 02, 2025 pm 05:15 PM

Comment comparer et gérer trois structures en langue go. Dans la programmation GO, il est parfois nécessaire de comparer les différences entre deux structures et d'appliquer ces différences au ...

Comment afficher les packages installés à l'échelle mondiale dans Go?Comment afficher les packages installés à l'échelle mondiale dans Go?Apr 02, 2025 pm 05:12 PM

Comment afficher les packages installés à l'échelle mondiale dans Go? En train de se développer avec le langage Go, GO utilise souvent ...

Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées?Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées?Apr 02, 2025 pm 05:09 PM

Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Lorsque vous utilisez Goland pour le développement du langage GO, de nombreux développeurs rencontreront des balises de structure personnalisées ...

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Navigateur d'examen sécurisé

Navigateur d'examen sécurisé

Safe Exam Browser est un environnement de navigation sécurisé permettant de passer des examens en ligne en toute sécurité. Ce logiciel transforme n'importe quel ordinateur en poste de travail sécurisé. Il contrôle l'accès à n'importe quel utilitaire et empêche les étudiants d'utiliser des ressources non autorisées.

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Télécharger la version Mac de l'éditeur Atom

Télécharger la version Mac de l'éditeur Atom

L'éditeur open source le plus populaire

SublimeText3 version anglaise

SublimeText3 version anglaise

Recommandé : version Win, prend en charge les invites de code !

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit