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

Добрый день. У меня есть родительский класс, который создает дочерние

процессы. Процессы должны завершаться в определенное время. Родитель создает процесс и идет дальше. Дочерний процесс создается и начинает свою работу.
Можно ли сделать так, чтобы дочерний процесс контролировал время и сам отключился?

18 ответов

22 просмотра

ну так сделай в дочерних классах setInterval(CheckTtl, 1000) ну и собственно как только наступит время, return и выходи из функи я так полагаю ты хочешь что-то вроде крона делать, я бы лучше подумал над event-emitter (на его основе реализовать), тогда с помощью родительского класса можно еще будет ими управлять

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

++ банальный вопрос, анальный ответ)

J-R Автор вопроса

Родитель создает дочерей для каждой записи в базе данных, проверяет каждые полчаса не появились ли в базе новые записи. Если появились - создает новые. С этим проблем нет. Дочерние процессы начинают свою работу: Слушают редис, обрабатывают входные данные и прочее. Суть в том, что когда я создаю дочерний процесс, то запускаются listener и прочее. Параллельно нужно еще проверять (или ждать) время до конца и отключаться по истечении времени. И лучше проверять именно в дочернем процессе. Как мне это сделать?

"Родитель создает дочерей для каждой записи в базе данных, проверяет каждые полчаса не появились ли в базе новые записи. Если появились - создает новые" зачем создавать на каждую запись во воркеру, если нужно знать лишь то что появились новые записи в бд?

А зачем отдельные процессы под чтение бд

Если появились - создает новые создает новые что? записи? воркеры?

изначально что за задача решается? зачем воркеры? какая предметная область? что имеено хотим поймать за событие?

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

J-R Автор вопроса

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

Ты спрашиваешь как воркер закончить? https://nodejs.org/api/worker_threads.html#worker_threads_worker_terminate

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

J-R Автор вопроса

Задача такая. Чтобы каждый процесс сам слушал редис и сам обрабатывал. И все в параллельных процессах под контролем родительского.

А почему задача именно такая? Интересно же как пришли к такому нестандартному решению

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
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
Карта сайта