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

Народ такой вопрос. php это синхронный язык. Но если мы

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

2 ответов

10 просмотров

да

Нету общего метода "как работает внутри". Есть масса вариаций. У меня была реализация: 1. Очередь в БД. 2. Обработчик-балансер - проверяет по крону каждую минуту длину очереди - на каждый 10 элементов очереди запускает отдельный процесс "разборщика" (система сдёргивала фалйы с другого хоста и разбирала данные) с лимитом в 20 процессов. Каждый процесс молотил пока не кончалась очередь. 3. Сами разборщики просто брали первую запись из очереди с флагом "wait", тут же обновляли эту запись на флаг "process" и уходили в обратку. Если разборщик не находил ни одной записи "wait" - завершение. Была и другая - болтался inotifywait, который по записи файла в каталог очереди запускал обработчик, обработчик по завершении работы проверял длину очереди - и если очередь длиннее 5 файлов - проверял сколько обработчиков запущено и если меньше чем "1 обработчик на каждые 5 файлов" - запускал дополнительные процессы. Вариантов масса на самом деле.

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

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

Кстати, а я вот тут подумал. Допустим, у нас имеется цикл который выполняет огромное количество итераций, но мы хотим, чтобы какие-то действия исполнилось только один раз. В Я...
The Bird of Hermes
23
Доброй ночи. Вопрос знатокам. Имеется некая таблица, результат которой выведен в DBGrid на форме. И есть форма, с помощью которой можно как добавить запись, так и отредактиров...
Евгений
28
а всё почему? потому что ассемблер в отличии от яву порождает множество пагубных привычек, среди которых например можно отметить использование глобальных переменных для всего ...
Mixail Frolov
35
анрей С какой целью зашёл?
КТ315
42
я часов 15 назад начал пытаться написать хоть что-то напоминающее ос и у меня есть проблема, которую я пытаюсь решить последние часов 5: есть крч 2 исходника с минимальным код...
Al1to
17
Кто нибудь из участников чата пишет на ассемблере под GNU/Linux?
Spiker01
24
Всем привет ребят! Мб кто-то сталкивался? adminСomponents .get("searchСomponents", use: searchComponents) .openAPI( summary: ...
Admin Adminov
2
Насколько моя реализация Exercise 1 плохая? data MessageType = Info | Warning | Error Int deriving (Show, Eq) type TimeStamp = Int data LogMessage = LogMessage ...
= ?
10
Кстати вопрос. Проанализировав свои проекты я понял, что в наиболее ценных из них Асм использовался для организации real-time процессов (внутри DOS). А какие есть способы сего...
Alexander Morozov
18
Добрый день, подскажите пожалуйста. RabbitMQ автоматически создаёт очередь если я отправляю сообщение в несуществующую очередь? Вопрос вроде тупой, но мнения разошлись. Одни г...
Elmo
9
Карта сайта