arrêt programmé à Golang
De plus en plus de systèmes logiciels nécessitent des opérations périodiques, telles que la sauvegarde des données, le nettoyage des journaux, les tâches planifiées, etc. Lors de la mise en œuvre de ces opérations périodiques, nous devons généralement utiliser des minuteries. Golang fournit une minuterie intégrée, mais lors de l'exécution d'opérations de chronométrage, comment pouvons-nous arrêter la minuterie à l'heure requise ?
De manière générale, nous pouvons utiliser le package time fourni par golang pour générer un timer. Par exemple :
timer1 := time.NewTimer(time.Second * 5) <-timer1.C fmt.Println("Timer 1 expired")
Le code ci-dessus affichera "Timer 1 expired" après 5 secondes. Le programme ici recevra un signal horaire du canal minuterie (timer1.C) après avoir attendu 5 secondes, réalisant ainsi la tâche de la minuterie. Il convient de noter que le minuteur créé à l'aide de la fonction time.NewTimer() se répétera automatiquement par défaut. Vous devez utiliser timer.Stop() pour mettre fin au minuteur, sinon le minuteur continuera à fonctionner.
Mais que se passe-t-il si nous devons arrêter le chronomètre dans un délai déterminé ? Par exemple, lorsque nous sauvegardons des données, si la durée de sauvegarde spécifiée est dépassée, nous devons arrêter de force le minuteur et mettre fin à la tâche de sauvegarde. À ce stade, nous devons lier le signal d'arrêt lorsque la minuterie est générée et envoyer des informations d'abandon au signal lorsqu'il doit être arrêté.
// 定时任务函数 func doDataBackup(stopSignal chan bool){ // 模拟数据备份,并每10秒执行一遍 for { select { case <-time.After(time.Second * 10): backupData() case stop := <-stopSignal: if stop { fmt.Println("Data backup stopped.") return } } } } func main() { stopSignal := make(chan bool) // 每10秒备份一次数据,规定备份时间为50秒 go doDataBackup(stopSignal) time.Sleep(time.Second * 50) // 操纵停止信号,结束任务 stopSignal <- true }
Dans le code ci-dessus, nous avons ajouté un signal d'arrêt stopSignal dans la fonction doDataBackup() pour accepter les informations d'arrêt forcé. Lorsque nous devons arrêter la tâche de sauvegarde, il nous suffit d'envoyer true au canal stopSignal, et la tâche de sauvegarde sera arrêtée de force.
Il est à noter qu'avant d'envoyer un signal d'arrêt au canal stopSignal, certaines opérations nécessaires telles que la sauvegarde des données et la libération des ressources peuvent être nécessaires. Ces opérations doivent être effectuées avant d'envoyer un signal d'arrêt au canal, sinon cela pourrait entraîner des problèmes tels qu'une perte de données.
Il convient de souligner que les tâches de sauvegarde ci-dessus sont effectuées au sein d'une seule coroutine. Si nous devons exécuter des tâches régulièrement dans plusieurs coroutines et les arrêter régulièrement, nous pouvons utiliser les packages sync.WaitGroup et context de Golang pour y parvenir. Par exemple :
func doTask(ctx context.Context, wg *sync.WaitGroup, id int){ defer wg.Done() fmt.Printf("goroutine %d started. ", id) for { select { case <-time.After(time.Second * 1): fmt.Printf("goroutine %d is working. ", id) case <-ctx.Done(): fmt.Printf("goroutine %d is stopped. ", id) return } } } func main() { wg := sync.WaitGroup{} ctx, cancel := context.WithTimeout(context.Background(), time.Second * 5) defer cancel() for i := 0; i < 3; i++ { wg.Add(1) go doTask(ctx, &wg, i) } wg.Wait() fmt.Println("Task completed.") }
Dans le code ci-dessus, nous avons créé trois coroutines. Chaque coroutine exécutera une tâche régulièrement et contrôlera la fermeture de la coroutine via le contexte entrant. Utilisez sync.WaitGroup pour vous assurer que toutes les tâches de coroutine sont terminées avant de terminer le programme. Utilisez la fonction WithTimeout() dans le contexte, qui stipule que le temps maximum d'exécution de la tâche est de 5 secondes. Si la tâche n'est pas terminée dans les 5 secondes, la tâche sera arrêtée de force et la coroutine se terminera.
Ce qui précède explique comment utiliser les minuteries dans Golang et comment mettre en œuvre un arrêt programmé. Grâce à ces méthodes, nous pouvons facilement mettre en œuvre diverses tâches périodiques et contrôler avec précision le temps d’exécution et l’heure d’arrêt des tâches en cas de besoin.
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Sujets chauds

OpenSSL, en tant que bibliothèque open source largement utilisée dans les communications sécurisées, fournit des algorithmes de chiffrement, des clés et des fonctions de gestion des certificats. Cependant, il existe des vulnérabilités de sécurité connues dans sa version historique, dont certaines sont extrêmement nocives. Cet article se concentrera sur les vulnérabilités et les mesures de réponse communes pour OpenSSL dans Debian Systems. DebianopenSSL CONNUTS Vulnérabilités: OpenSSL a connu plusieurs vulnérabilités graves, telles que: la vulnérabilité des saignements cardiaques (CVE-2014-0160): cette vulnérabilité affecte OpenSSL 1.0.1 à 1.0.1F et 1.0.2 à 1.0.2 Versions bêta. Un attaquant peut utiliser cette vulnérabilité à des informations sensibles en lecture non autorisées sur le serveur, y compris les clés de chiffrement, etc.

La bibliothèque utilisée pour le fonctionnement du numéro de point flottante dans le langage go présente comment s'assurer que la précision est ...

Problème de threading de file d'attente dans Go Crawler Colly explore le problème de l'utilisation de la bibliothèque Crawler Crawler dans le langage Go, les développeurs rencontrent souvent des problèmes avec les threads et les files d'attente de demande. � ...

Chemin d'apprentissage du backend: le parcours d'exploration du front-end à l'arrière-end en tant que débutant back-end qui se transforme du développement frontal, vous avez déjà la base de Nodejs, ...

Cet article présente une variété de méthodes et d'outils pour surveiller les bases de données PostgreSQL sous le système Debian, vous aidant à saisir pleinement la surveillance des performances de la base de données. 1. Utilisez PostgreSQL pour reprendre la surveillance Afficher PostgreSQL lui-même offre plusieurs vues pour surveiller les activités de la base de données: PG_STAT_ACTIVITY: affiche les activités de la base de données en temps réel, y compris les connexions, les requêtes, les transactions et autres informations. PG_STAT_REPLIcation: surveille l'état de réplication, en particulier adapté aux grappes de réplication de flux. PG_STAT_DATABASE: Fournit des statistiques de base de données, telles que la taille de la base de données, les temps de validation / recul des transactions et d'autres indicateurs clés. 2. Utilisez l'outil d'analyse de journaux pgbadg

La différence entre l'impression de chaîne dans le langage go: la différence dans l'effet de l'utilisation de fonctions println et string () est en Go ...

Dans le cadre du cadre de beegoorm, comment spécifier la base de données associée au modèle? De nombreux projets Beego nécessitent que plusieurs bases de données soient opérées simultanément. Lorsque vous utilisez Beego ...

Le problème de l'utilisation de Redessstream pour implémenter les files d'attente de messages dans le langage GO consiste à utiliser le langage GO et redis ...
