процессы. Процессы должны завершаться в определенное время. Родитель создает процесс и идет дальше. Дочерний процесс создается и начинает свою работу.
Можно ли сделать так, чтобы дочерний процесс контролировал время и сам отключился?
ну так сделай в дочерних классах setInterval(CheckTtl, 1000) ну и собственно как только наступит время, return и выходи из функи я так полагаю ты хочешь что-то вроде крона делать, я бы лучше подумал над event-emitter (на его основе реализовать), тогда с помощью родительского класса можно еще будет ими управлять
та вообще непонятно что сделать нужно)
xyproblem.info какую задачу решить пытаетесь?
можно. а как - надо? если есть - завершение по времени, то - кто-то должен время контролировать это может делать - родитель, или еще кто, кому поручено. и - сообщать процессу - все, хватит. процесс слушает, во время своей работы, так или сяк может и сам процесс - стартовал, запомнил время, и во время работы сверяется и что такое - отключился? от кого/чего он должен отключиться? и класс - это про другое. класс - это про организацию кода, а не про эту задачу да и само решение - стартовать процессы и чтобы они умирали - может быть левое. как выше правильный вопрос какую задачу решить пытаетесь?
++ банальный вопрос, анальный ответ)
Родитель создает дочерей для каждой записи в базе данных, проверяет каждые полчаса не появились ли в базе новые записи. Если появились - создает новые. С этим проблем нет. Дочерние процессы начинают свою работу: Слушают редис, обрабатывают входные данные и прочее. Суть в том, что когда я создаю дочерний процесс, то запускаются listener и прочее. Параллельно нужно еще проверять (или ждать) время до конца и отключаться по истечении времени. И лучше проверять именно в дочернем процессе. Как мне это сделать?
"Родитель создает дочерей для каждой записи в базе данных, проверяет каждые полчаса не появились ли в базе новые записи. Если появились - создает новые" зачем создавать на каждую запись во воркеру, если нужно знать лишь то что появились новые записи в бд?
А зачем отдельные процессы под чтение бд
Если появились - создает новые создает новые что? записи? воркеры?
изначально что за задача решается? зачем воркеры? какая предметная область? что имеено хотим поймать за событие?
давайте все же разделим что надо? от того - что уже понакручено. как по мне - у вас что-то очень понакручено...
Каждая запись - это параметры воркера. Каждый воркер имеет разные параметры и слушает один и тот же редис, чтобы каждый воркер мог поймать одни данные и обработать их у себя. Считай, что-то наподобие акций
какое отношение имеют акции к воркерам
Ты спрашиваешь как воркер закончить? https://nodejs.org/api/worker_threads.html#worker_threads_worker_terminate
А откуда уверенность в том, что нужны несколько процессов, которые слушают один редис? Почему нельзя, например, слушать редис в одном процессе, а при наступлении событий кидать информацию о них в очередь, которую разгребают другие процессы?
Задача такая. Чтобы каждый процесс сам слушал редис и сам обрабатывал. И все в параллельных процессах под контролем родительского.
А почему задача именно такая? Интересно же как пришли к такому нестандартному решению
99% кейс XY проблемы, а то бред какой то
Обсуждают сегодня