Какие технические истории есть — не про архитектуру сверху, а про углубление в детали, реальный проблемный кейс?
Расскажи про реализацию batch-процесса для перерасчёта исторических данных. Зачем каждую ночь пересчитывать? Сколько данных хранили?
Расскажи, чем ты занимался на текущем месте работы?
Для API Gateway один Load Balancer, для WebSocket другой — итого два LB в системе?
func (c *Client) Send(ctx context.Context, messages []Message, maxWorkers int) error { sem := make(chan struct{}, maxWorkers) var wg sync.WaitGroup var resultErr error var once sync.Once for _, msg := range messages { wg.Add(1) go func(msg Message) { defer wg.Done() sem <- struct{}{} defer func() { <-sem }() body, err := json.Marshal(msg) if err != nil { once.Do(func() { resultErr = err; cancel() }) return } req, _ := http.NewRequestWithContext( ctx, http.MethodPost, c.url, bytes.NewReader(body), ) req.Header.Set("Content-Type", "application/json") resp, err := c.httpClient.Do(req) if err != nil { once.Do(func() { resultErr = err; cancel()}) return } defer resp.Body.Close() if resp.StatusCode >= 500 { once.Do(func() { resultErr = fmt.Errorf("server error") cancel()}) return } c.sentCount.Add(1) time.Sleep(time.Second) }(msg) } wg.Wait() }
Расскажи подробнее про семафоры.
Что вы делаете, если понимаете, что сроки поджимают и вы не успеваете?
Насколько корректно поведение метода Stop при повторном вызове, когда первый вызов ждёт, а второй сразу делает return?
Расскажи какую-нибудь интересную инженерную задачу, которой ты занимался — сложную, которую можно рассказать друзьям.
Какая будет задержка между игроками — в среднем и в худшем случае?
Postgres с JSONB — можно ли использовать как NoSQL?
Что именно ты реализовывала в этом микросервисе?
Клиент может стримить голосовые напрямую из S3 через CDN, как и с картинками — загружать в ближайший по гео CDN?
Что произойдёт при чтении из закрытого канала в Go?
Как прорабатываете архитектуру — есть ли архитектор в команде, платформа, комитет?
В чём отличие между Kafka и RabbitMQ?
На основании чего делали партиционирование в Amazon Athena?
Как можно использовать встроенные структуры для имитации наследования в Go?
Как вы выбираете способ решения сложной задачи? Как принимаете архитектурные решения?
В какой момент вы даёте ACK? Сразу при получении или после обработки?