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

Вообще сам nginx умеет конфиг перегружать без остановки. А в реализации

ингресса кубера он так не умеет?
контроллер бежит в одном контейнере с самим nginx, кажется им ничего не стоило это сделать?!

30 ответов

57 просмотров

Насколько я знаю, именно это и происходит, релоад же. Не рестарт.

Без остановки не умеет, а вот без прерывания текущих запросов может

Andrey-Panov Автор вопроса
Владимир Муковоз
Без остановки не умеет, а вот без прерывания текущ...

ну пусть он даже и останавливается, он же там завершает все запросы и только потом гасит процесс, и при этом уже обслуживает новые?! вроде нет проблемы?

Andrey Panov
ну пусть он даже и останавливается, он же там заве...

есть, коннекты сбрасываются, но можно поставить таймаут, но они все равно сбросяться после таймаута. Актуально для websocket но даже если не websocket, это довольно дорогая операция, спаун новых процессов, заново tls хэндшейки, и всё это на каждый релоад. А в кубе релоады могут быть частыми из-за динамичности среды. Я даже ловил такое что nginx тупо повис и не отвечал на live пробы после ряда релоадов (аплаились новые ingress'ы), в кластере где были вебсокеты и соотвественно настроен shutdown timeout. Было > 120 процессов в поде и ошибки - не могу за спавнить процесс бла бла бла

Владимир Муковоз
Почитайте внимательнее

Nginx reload сто лет в обед. Что именно не умеет без остановки?

Не умеет

George Gaál
Он же воркеры пересоздает, фуфуфу

Ну и пусть, главное без downtime

Andrey Kartashov
Ну и пусть, главное без downtime

Так это и есть даунтайм. Вебсокеты рвутся, большие файлы не качаются, вот это всё

Andrey Kartashov
Nginx reload сто лет в обед. Что именно не умеет б...

nginx reload это и есть остановка, а потом запуск, не умеет он без остановки, почитайте внимательнее про nginx reload

Andrey Kartashov
Ну и пусть, главное без downtime

а разницу ты почуствуешь когда у тебя будут миллионы соединений, и воркеры не будут заверщаться пока они их не обработают)), и у тебя релоад будет длиться несколько минут))), сразу поймёшь что такое релоад и почему всё таки изменения с остановкой применяются Они применяются без разрыва текущих соединений, это да, но с остановкой

Владимир Муковоз
а разницу ты почуствуешь когда у тебя будут миллио...

надуманная проблема, есть ретраи. если имеется множество вебсокетов, то это не ошибка реализации ингреса, а ошибка архитектора, для них должен быть отдельный ингресс-контроллер с отдельными ингресами, которые, как правило, меняются на порядки реже

Марат Рахимов
надуманная проблема, есть ретраи. если имеется мно...

а грейсфуллшутдауна вполне хватает на завершение запросов веба, если веб обрабатывает запросы несколько минут, то наверно есть у веба проблемы посерьезнее, чем внезапно прерванный запрос из-за перезапуска воркеров nginx

Марат Рахимов
надуманная проблема, есть ретраи. если имеется мно...

Отдельные ингрессы для вебсокетов? Это что-то странное

Stanislav Motriy
Отдельные ингрессы для вебсокетов? Это что-то стра...

вайнот, если сильно болит от их сбросов просто гражданин выше рассказал, как больно, что запросы рвутся с миллионами миллиардов запросов - есть решение

Марат Рахимов
вайнот, если сильно болит от их сбросов просто гр...

Отдельный ингресс чисто для вебсокетов - ИМХО, как раз и есть ошибка архитектуры.

Владимир Муковоз
nginx reload это и есть остановка, а потом запуск,...

Тебе какая разница, что подменяется, конфиг в памяти или процесс? В конечном итоге какой-то указатель у тебя вначале указывал на одну структуру, потом атомарно поменялся и стал указывать на другую. Меняется только путь, а для конечного пользователя выглядит "одинаково", сначала соединения "видели" один домен, потом стали "видеть" два. А не так, что текущие соединения прервались, потом соединения перестали приниматься, потом стали приниматься с новым конфигом.

Владимир Муковоз
а разницу ты почуствуешь когда у тебя будут миллио...

А в условиях жестокой нехватки ресурсов у тебя любой подход будет "течь" через дырявую абстракцию при смене конфига, потому как тебе старый конфиг и старые соединения надо держать в памяти, пока они не завершились.

Марат Рахимов
надуманная проблема, есть ретраи. если имеется мно...

я не говорю о проблеме, я говорю сейчас больше о терминалогии, я докапываюсь до того что тут кто-то начал утверждать что настройки применяются без перезапуска и уточняю, что перезапуск есть, и релоад это не применение без перезапуска, а применение без разрыва текущих соединений и всё

Владимир Муковоз
я не говорю о проблеме, я говорю сейчас больше о т...

Договорились. Дальше спорить не имеет смысла, вопрос договоренности терминов, что считать перезапуском. В моём понимании перезапуск - это остановка сервиса, в твоём - когда отдельный процесс останавливается и запускается следующий. Опустим подробности, что процессы и потоки в пуле воркеров могут меняться и без команды на релоад.

Владимир Муковоз
я не говорю о проблеме, я говорю сейчас больше о т...

таким образом роллаут деплоймента - с "остановкой", мы точно хотим именно этот термин использовать?

Andrey Kartashov
Договорились. Дальше спорить не имеет смысла, вопр...

поподробнее о том что процессы в пуле воркеров могут меняться, я впервые о таком слышу

Марат Рахимов
таким образом роллаут деплоймента - с "остановкой"...

я не упоминал вообще в данном случае кубер, я дискутировал исключительно на тему nginx

Владимир Муковоз
поподробнее о том что процессы в пуле воркеров мог...

Что будет, если воркер по какой-либо причине сдохнет? Мастер поднимет новый.

Andrey Kartashov
Что будет, если воркер по какой-либо причине сдохн...

верно, но я бы не назвал это штатной ситуацией, по какой причине он сдохнет?* оом? или ошибка в коде? это нифига не штатная ситуация и в таком случае воркер ещё и оборвёт активные с ним соединения

Владимир Муковоз
верно, но я бы не назвал это штатной ситуацией, по...

Навскидку не могу сказать, что есть какой-то штатный сценарий кроме релоада, при котором именно процессы заменяются. Но факт такой есть, мастер следит за воркерами и смерть воркера не приводит к полной остановке сервиса.

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

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

Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
55
Я тут за тем, чтобы задать вопрос, так как не знаю ассемблер, учу с/с++. Короче, насколько дорога операция перехода в функцию при ее вызове? Дело в том, что в с++ есть макросы...
Максим Рябцев
12
А какие чаты вообще в ходу? Auto aim? И что еше
do you think you're better off alone? А
13
Привет, нужен совет старших товарищей. Есть глобальная переменная var DefaultDataFolder:string; инициализируем DefaultDataFolder:='a:\_OUT\'; есть примитивная процедур...
Max Otto
14
hello friends. Do you know how can I learn getx? I have a software project that I should deliver it up to 5 weeks later and I need to learn firebase too. I will be thankfull
AmirHossein Razavi
15
Доброе время суток! у меня тут иноды закончились. и понял почему по сути кстит, я периодически очищаю постгрес и сентри контайнер: postgres=# DELETE FROM nodestore_node WHER...
Юсиф Насиров
9
Вопрос. Теоретический. Есть список команд. Команды отправляю в обработку некой функции, по очереди. Разные команды могут давать разные результаты после обработки. В зависимос...
Serjone
7
lazarus-3.2.0/gtk, linux патч "имя проекта по умолчанию project1 -> prj" день добрый не нравится "именя проекта по умолчанию" (project1), к.раз приходится переименовывать (н...
livontiy
5
Коллеги, а в чём сейчас хорошо писать на перле, в смысле ide? Пробовал в идее с плагином, подсветка есть, даже какие-то предупреждения есть, но рефакторинга считай нет. Перене...
Дмитрий Петров
9
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Карта сайта