Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: worker, context, cancellation, goroutine

Как корректно остановить несколько воркеров через общий контекст?

Проверяет опыт работы с воркерами.

Короткий ответ

Создайте общий context.Context и передайте его всем воркерам. Каждый воркер в select слушает <-ctx.Done() и завершает работу, завершая весь пул одним сигналом отмены.

Длинный ответ

Идея: контекст — механизм широковещательной отмены.

  • Шаги:

  1. В main создать ctx, cancel := context.WithCancel(parent);

  2. Передать ctx всем воркерам при запуске;

  3. Внутри воркера: select { case <-ctx.Done(): return … }.

  • Пример:

ctx, cancel := context.WithCancel(context.Background())
defer cancel()

for i := 0; i < N; i++ {
    go func(id int) {
        for {
            select {
            case <-ctx.Done():
                return
            case job := <-jobs:
                _ = handle(job)
            }
        }
    }(i)
}

// ... по сигналу:
cancel()
  • Особенности:

  • закрытие Done() — broadcast для всех горутин;

  • завершайте фоновые операции и закрывайте каналы.

  • Вывод: общий контекст обеспечивает синхронную, безопасную остановку пула воркеров.

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    5

  • Сложность:

    4

Навыки

  • Golang

    Golang

Ключевые слова

#worker

#context

#cancellation

#goroutine

Подпишись на Golang Developer в телеграм

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.