Назад к вопросам
OZON
Senior
6
Вопрос о медленном сервисе На примере создания заказа. Есть запрос на сервис и есть ответ, между этими двумя действиями мы складываем в аналитику товары которые заказали (например для подсчета популярности товаров). Сервис аналитики периодически работает медленно или вовсе таймаутит, и мы не успеваем ответить, теряем заказы. Что делать, что бы перестать терять заказы, и деньги соответственно? Придумать как распараллелить заказ и аналитику.
Компании, где спрашивали
Ответ от нейросети
sobes.tech AI
Чтобы не терять заказы из-за медленной аналитики, нужно отделить обработку заказа от аналитики и сделать их асинхронными.
Пример решения:
- При создании заказа сервис сразу отвечает клиенту, подтверждая заказ.
- Информация о заказе отправляется в очередь сообщений (например, Kafka, RabbitMQ).
- Отдельный сервис или воркер читает сообщения из очереди и обновляет аналитику.
Такой подход позволяет распараллелить обработку и не блокировать основной поток заказа из-за медленной аналитики.
Пример на 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)
}
Такой подход повышает отказоустойчивость и производительность.