Sobes.tech
Назад к вопросам
Senior
6

Вопрос о медленном сервисе На примере создания заказа. Есть запрос на сервис и есть ответ, между этими двумя действиями мы складываем в аналитику товары которые заказали (например для подсчета популярности товаров). Сервис аналитики периодически работает медленно или вовсе таймаутит, и мы не успеваем ответить, теряем заказы. Что делать, что бы перестать терять заказы, и деньги соответственно? Придумать как распараллелить заказ и аналитику.

Компании, где спрашивали
OZONOZON

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

sobes.tech AI

Чтобы не терять заказы из-за медленной аналитики, нужно отделить обработку заказа от аналитики и сделать их асинхронными.

Пример решения:

  1. При создании заказа сервис сразу отвечает клиенту, подтверждая заказ.
  2. Информация о заказе отправляется в очередь сообщений (например, Kafka, RabbitMQ).
  3. Отдельный сервис или воркер читает сообщения из очереди и обновляет аналитику.

Такой подход позволяет распараллелить обработку и не блокировать основной поток заказа из-за медленной аналитики.

Пример на Go с использованием канала для имитации очереди:

type Order struct {
    ID    string
    Items []string
}

var analyticsChan = make(chan Order, 100)

func createOrder(order Order) {
    // Сразу подтверждаем заказ
    fmt.Println("Order created:", order.ID)
    // Отправляем в аналитику асинхронно
    go func() { analyticsChan <- order }()
}

func analyticsWorker() {
    for order := range analyticsChan {
        // Обработка аналитики
        fmt.Println("Processing analytics for order:", order.ID)
        time.Sleep(time.Second * 2) // имитация медленной работы
    }
}

func main() {
    go analyticsWorker()
    createOrder(Order{ID: "123", Items: []string{"item1", "item2"}})
    time.Sleep(time.Second * 5)
}

Такой подход повышает отказоустойчивость и производительность.