170 похожих чатов

Всем привет func main() { if err :=

run(); err != nil {
log.Fatalf("run(). Error: '%v'\n", err)
}
}

func run() error {
router := mux.NewRouter().StrictSlash(true)
router.HandleFunc("/api/v1/authorization", handlers.Authorization).Methods(http.MethodPost)

logger.DebugInfo("Server listening on http://0.0.0.0:8082/")
if err := http.ListenAndServe("0.0.0.0:8082", router); err != nil {
return err
}

return nil
}
Почему ка ктолько в методе Authorization есть if{ return }
то сервис моментально падает и докерконтенйер моментально гасится ?

Что я делаю не так?

6 ответов

14 просмотров

listenAndServer в горутину запихни, а завершение программы жди из канала os.Signal s := &http.Server{ Addr: fmt.Sprintf(":%d", cfg.Bind), Handler: r, ErrorLog: zap.NewStdLog(zap.L()), ReadHeaderTimeout: time.Duration(cfg.ReadHeadersTimeout) * time.Millisecond, ReadTimeout: time.Duration(cfg.ReadTimeout) * time.Millisecond, WriteTimeout: time.Duration(cfg.HandlerTimeout+50) * time.Millisecond, } l.Info("starting http service") go func() { err := s.ListenAndServe() if err != nil { l.Fatal(err.Error()) } }() c := make(chan os.Signal) signal.Notify(c, syscall.SIGINT, syscall.SIGTERM) <-c l.Warn("stopping http service") ctx, cancel := context.WithCancel(context.Background()) go func() { <-c cancel() }() if err = s.Shutdown(ctx); err != nil { l.Fatal(err.Error()) } l.Warn("stopped")

Slava-Pinchuk Автор вопроса
gudron
listenAndServer в горутину запихни, а завершение п...

а скажите, пожалуйста зачем её ложить в горутину? Я пока не вкурил причину данного подхода...

ну отладка же есть ))) почему "падает"?

Slava-Pinchuk Автор вопроса
Alexey Shumkin
ну отладка же есть ))) почему "падает"?

интеграционнеы тесты проходят всё ок, чего падает пок ане разобрался

Slava-Pinchuk Автор вопроса
Alexey Shumkin
ну "падение" в чём заключается-то?

Все норм, оказалось косяки на стороне девопса

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта