Sobes.tech
Назад к вопросам
Junior — Middle
78

Какие основные шаблоны взаимодействия Kafka с микросервисами тебе известны?

Компании, где спрашивали
Магнит Тех

Ответ от нейросети

sobes.tech AI

Основные шаблоны взаимодействия Kafka с микросервисами:

  1. Event-Driven Architecture (EDA) — микросервисы публикуют события в Kafka, другие микросервисы подписываются на эти события и реагируют на них. Это асинхронный обмен сообщениями, позволяющий снизить связность между сервисами.

  2. Command Query Responsibility Segregation (CQRS) — команды и запросы обрабатываются разными микросервисами, при этом Kafka используется для передачи команд или событий изменения состояния.

  3. Event Sourcing — все изменения состояния микросервиса сохраняются как последовательность событий в Kafka, что позволяет восстанавливать состояние или делать аудит.

  4. Log Aggregation — Kafka используется для сбора логов и метрик от микросервисов для последующего анализа.

Пример простого продюсера на Go с использованием библиотеки sarama:

package main

import (
    "github.com/Shopify/sarama"
    "log"
)

func main() {
    producer, err := sarama.NewSyncProducer([]string{"localhost:9092"}, nil)
    if err != nil {
        log.Fatal(err)
    }
    defer producer.Close()

    msg := &sarama.ProducerMessage{
        Topic: "events",
        Value: sarama.StringEncoder("Hello Kafka"),
    }

    partition, offset, err := producer.SendMessage(msg)
    if err != nil {
        log.Fatal(err)
    }
    log.Printf("Message is stored in partition %d, offset %d\n", partition, offset)
}