


Comment se connecter et utiliser Kafka avec une application Go?
Jul 17, 2025 am 03:55 AMLes étapes clés pour se connecter avec GO et l'utilisation de Kafka incluent l'installation de la bibliothèque Kafka-Go, la rédaction de producteurs pour envoyer des messages, la rédaction de consommateurs pour recevoir des messages et faire attention aux problèmes communs. 1. Installez la bibliothèque Kafka-Go pour gérer les dépendances via des mods GO; 2. Créer des producteurs pour envoyer des messages au sujet spécifié à l'aide d'écrivains; 3. Créer des consommateurs pour utiliser le lecteur pour retirer les messages du sujet spécifié; 4. Faites attention à des détails tels que l'adresse du courtier, le nom du sujet, les paramètres de groupe de consommateurs et le réglage des performances.
Il n'est pas difficile de se connecter et d'utiliser les applications GO de Kafka, mais certains détails doivent être prêts attention. La communauté Go a plusieurs bibliothèques de clients Kafka relativement matures, les plus couramment utilisées sont sarama
et kafka-go
. Cet article se concentrera sur kafka-go
car son API est plus moderne et plus de style.

Ce qui suit est quelques points clés pour vous aider à démarrer rapidement.
Installer Kafka-Go
La première étape consiste bien s?r à installer la bibliothèque. Vous pouvez utiliser GO MOD pour gérer les dépendances:

Allez obtenir github.com/segmentio/kafka-go
Une fois l'installation terminée, vous pouvez commencer à écrire aux producteurs et aux consommateurs.
écrivez un simple producteur de Kafka
Le producteur est responsable de l'envoi de messages au sujet de Kafka. Le processus de base est de créer un écrivain, puis d'écrire des données sur le sujet spécifié.

package principal importer ( "contexte" "FMT" "github.com/segmentio/kafka-go" "temps" ) func main () { // Créer un écrivain et se connecter au courtier Kafka écrivain: = kafka.newwriter (kafka.writerConfig { Brokers: [] String {"LocalHost: 9092"}, Sujet: "My-Topic", Balancer: & kafka.leastbytes {}, }) // Envoyez un message err: = writer.writeMessages (context.background (), Kafka.Message { Clé: [] byte ("key-a"), Valeur: [] BYTE ("Hello World"), }, ) Si err! = Nil { panique ("ne pouvait pas écrire de message" err.Error ()) } fmt.println ("message envoyé") écrivain.close () }
-
Brokers
sont la liste d'adresses des grappes de Kafka. -
Topic
est le thème cible. -
Balancer
est utilisé pour contr?ler comment les messages sont alloués aux partitions.LeastBytes
sont une stratégie relativement courante.
écrivez un simple consommateur Kafka
Le consommateur est chargé de retirer les messages de Kafka. Vous devez spécifier le sujet et le groupe à consommer.
package principal importer ( "contexte" "FMT" "github.com/segmentio/kafka-go" "temps" ) func main () { lecteur: = kafka.newreader (kafka.readerconfig { Brokers: [] String {"LocalHost: 9092"}, Sujet: "My-Topic", GroupID: "My-Groupe", StartOffset: kafka.firstoffset, }) pour { msg, err: = reader.readMessage (context.background ()) Si err! = Nil { panique ("Message de lecture d'erreur:" Err.Error ()) } fmt.printf ("re?u:% s \ n", String (msg.value)) } Reader.Close () }
-
GroupID
est utilisé pour les groupes de consommateurs, et plusieurs consommateurs peuvent partager un groupe pour atteindre l'équilibrage de charge. -
StartOffset
détermine où démarrer la consommation etFirstOffset
signifie partir de zéro.
Des questions et des notes fréquemment posées
Vous ne pouvez pas se connecter à Kafka?
Vérifiez si l'adresse du courtier de Kafka est correcte et si le pare-feu a publié le port 9092.Les consommateurs ne peuvent pas recevoir les nouvelles?
Vérifiez que le nom du sujet est correct, si Kafka a écrit un message et si le groupe de consommateurs est confronté.-
Suggestions de réglage des performances:
- L'envoi de messages par lots peut améliorer les performances des producteurs.
- Les consommateurs peuvent définir
MaxWait
pour contr?ler la fréquence de traction. - Définir raisonnablement le nombre de partitions et de consommateurs pour éviter le gaspillage de ressources.
-
Mécanisme de confirmation du message:
- Kafka est asynchrone pour soumettre des décalages par défaut, qui peuvent être contr?lés manuellement via
reader.SetOffset()
. - Si vous souhaitez contr?ler avec précision le moment de la soumission de décalage, vous pouvez le soumettre manuellement après avoir consommé le message.
- Kafka est asynchrone pour soumettre des décalages par défaut, qui peuvent être contr?lés manuellement via
Fondamentalement, c'est tout. GO n'est pas compliqué pour Kafka, mais vous devez prêter attention aux détails de la configuration et à la gestion des exceptions d'exécution. Si vous commencez tout juste à l'utiliser, il est recommandé de commencer par des exemples simples, puis d'ajouter progressivement la réessayer, la journalisation, la surveillance et d'autres mécanismes.
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

Undress AI Tool
Images de déshabillage gratuites

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.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à 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)

La réponse est: les applications GO n'ont pas de disposition de projet obligatoire, mais la communauté adopte généralement une structure standard pour améliorer la maintenabilité et l'évolutivité. 1.CMD / Stocke l'entrée du programme, chaque sous-répertoire correspond à un fichier exécutable, tel que cmd / myapp / main.go; 2. Le code privé à l'intérieur / stocke ne peut pas être importé par des modules externes et est utilisé pour encapsuler la logique et les services commerciaux; 3.PKG / Stores Bibliothèques réutilisables publiquement pour importer d'autres projets; 4.API / stocke éventuellement OpenAPI, Protobuf et autres fichiers de définition d'API; 5.Config /, Scripts / et Web / Store Files de configuration, scripts et ressources Web respectivement; 6. Le répertoire racine contient Go.mod et Go.sum

L'utilisation de Bufio.Scanner est la méthode la plus courante et la plus efficace de lecture de fichiers en ligne par ligne, et convient pour gérer des scénarios tels que les fichiers gros, l'analyse du journal ou les fichiers de configuration. 1. Ouvrez le fichier à l'aide d'os.open et assurez-vous de fermer le fichier via Deferfile.close (). 2. Créez une instance de scanner via bufio.newscanner. 3. Appelez Scanner.Scan () dans la boucle FOR à lire la ligne par ligne jusqu'à ce que FAUS soit renvoyé pour indiquer que la fin du fichier est atteinte ou une erreur se produit. 4. Utilisez Scanner.Text () pour obtenir le contenu de ligne actuel (à l'exclusion des caractères Newline). 5. Vérifier le scanner.err () Une fois la boucle terminée pour attraper d'éventuelles erreurs de lecture. Cette méthode a un effet de mémoire

Le routage dans les applications GO dépend de la complexité du projet. 1. La bibliothèque standard NET / HTTPSERVEMUX convient aux applications simples, sans dépendances externes et est légère, mais ne prend pas en charge les paramètres d'URL et la correspondance avancée; 2. Les routeurs tiers tels que le CHI fournissent des middleware, des paramètres de chemin et un routage imbriqué, qui convient à la conception modulaire; 3. Gin a d'excellentes performances, un traitement JSON intégré et des fonctions riches, ce qui convient aux API et aux microservices. Il doit être sélectionné selon que la flexibilité, les performances ou l'intégration fonctionnelle sont nécessaires. Les petits projets utilisent des bibliothèques standard, les projets moyens et grands recommandent du chi ou du gin et finissent par obtenir une expansion fluide de simple à complexe.

L'instruction IF-ELSE dans GO ne nécessite pas de supports mais doit utiliser des accolades bouclées. Il prend en charge l'initialisation des variables dans si pour limiter la portée. Les conditions peuvent être jugées via la cha?ne ELLEIF, qui est souvent utilisée pour la vérification des erreurs. La combinaison de la déclaration et des conditions variables peut améliorer la simplicité et la sécurité du code.

Dans GO, les constantes sont déclarées en utilisant le mot-clé const, et la valeur ne peut pas être modifiée et ne peut être pas de type ni de type; 1. Une seule déclaration constante telle que constpi = 3,14159; 2. Plusieurs déclarations constantes dans le bloc sont telles que const (pi = 3,14159; linguisse = "go"; isCool = true); 3. Constantes de type explicite telles que ConstseConDSInMinuteInt = 60; 4. Utilisez Iota pour générer des valeurs d'énumération, telles que const (dimanche = iota; lundi; mardi) attribuera des valeurs 0, 1 et 2 en séquence, et Iota peut être utilisé pour des expressions telles que les opérations binaires; Les constantes doivent déterminer la valeur au moment de la compilation,

Le package Flag de Go peut facilement analyser les paramètres de ligne de commande. 1. Utilisez Flag.Type () pour définir des drapeaux de type tels que les cha?nes, les entiers et les booléens; 2. Vous pouvez analyser les drapeaux aux variables via Flag.Typevar () pour éviter les opérations de pointeur; 3. Après avoir appelé Flag.Parse (), utilisez Flag.Args () pour obtenir des paramètres de position ultérieurs; 4. Implémentation de l'interface Flag.Value peut prendre en charge les types personnalisés pour répondre à la plupart des exigences CLI simples. Les scénarios complexes peuvent être remplacés par la bibliothèque SPF13 / COBRA.

Gorun est une commande pour compiler et exécuter rapidement les programmes GO. 1. Il termine la compilation et l'exécution en une seule étape, génère des fichiers exécutables temporaires et les supprime une fois le programme terminé; 2. Il convient aux programmes indépendants contenant des fonctions principales, qui sont faciles à développer et à tester; 3. Il prend en charge l'opération multi-fichiers et peut être exécutée via Gorun * .go ou répertorie tous les fichiers; 4. Il traite automatiquement les dépendances et utilise le système de modules pour analyser les packages externes; 5. Il ne convient pas aux bibliothèques ou aux packages et ne génère pas de fichiers binaires persistants. Par conséquent, il convient aux tests rapides pendant les scripts, l'apprentissage et les modifications fréquentes. C'est une fa?on efficace et concise de courir.

Pour vous connecter aux bases de données SQL dans GO, vous devez utiliser le package de base de données / SQL et un pilote de base de données spécifique. 1. Importez des packages et des pilotes de base de données (tels que github.com/go-sql-driver/mysql), notez que les soulignements avant que les pilotes indiquent qu'ils ne sont utilisés que pour l'initialisation; 2. Utilisez sql.open ("mysql", "utilisateur: mot de passe @ tcp (localhost: 3306) / dbname") pour créer une poignée de base de données et appeler db.ping () pour vérifier la connexion; 3. Utilisez db.query () pour exécuter des requêtes, et db.exec () pour exécuter
