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

Доброго времени суток. Подскажите, пожалуйста, что лучше: pcntl_fork или же pthreads? Задача

такая: через cron запускается раз в 10 минут некоторый процесс, который порождает дочерние. В один момент в системе находятся порядка 200-ста процессов.
После первого порождения 200-сот процессов родительский процесс ожидает в цикле завершение первого из дочерних. Как только тот завершился - запускается 201-ый, как только завершился второй - запускается 202-ой. В общем, в среднем, в системе всегда порядка 200-ста процессов. Всего, суммарно, около 1000 задач выполняется.

Раньше использовал pcntl_fork, затем (исходя из того, что работа ведётся в Symfony) перешёл на Symfony Process. Но на удивление с ростом нагрузки Symfony Process перестал справляться и пришлось вернуться к pcntl_fork.
Сейчас вот думаю в сторону pthreads. Кто-нибудь работал? Для такой задачи как у меня, как думаете, стоит ли переходить на него?

2 ответов

8 просмотров

эти штуки же разные функции выполняют >Symfony Process перестал справляться и пришлось вернуться к pcntl_fork. какие симптомы? не успевает в 10 минут? если есть уже подготовленные данные можно попробовать форком, чтобы 2 раза выборки нужные не делать

Выбирая между pcntl_fork и pthreads, я бы выбрал для этой задачи golang

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

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

А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Нужен пулл реквест с хаммингберд + асинкхттпклиент или хаммингберд + юрлсессия?
Karl {🌪️}{🐊} Shinobi
7
Всем привет. Поделитесь, пожалуйста, опытом. Есть форма, на которой имеется dbgrid и кнопки: добавить, редактировать, удалить. Если нет записей в dbgrid, то кнопки редактирова...
Евгений
5
может там как раз сжатие?
Дмитрий
7
Как структуру (из MSVC) в которой описаны битовые поля описать для fasm? Вот например это (fBinary...fDummy2 - это физически 1 DWORD): typedef struct _DCB { DWORD DCBlength;...
Евгений
3
type TExtensions<GExtender>=class function GetExtension<GEntityExtenderType>:GEntityExtenderType; end; function TExtensions<GExtender>.GetExtension<GEntityExtenderType...
zamtmn
9
Карта сайта