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

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

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

2 ответов

9 просмотров

да

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

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

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

коллеги, добрый вечер! А никто не знает как модальная форма может себя закрыть? Ну допустим модальная форма определила, что смысла ей работать нет и хочет вернуть modalResult...
Михаил
83
А если изначально бот работал так : есть сайт онлайн школы. У каждого ученика свой кабинет. Где он авторизуется по своим данным. И уже в кабинете, на самом сайте делает оплату...
Денис 💡 Фрилансер
13
А что ты вообще делаешь ?
Yesgoter
13
На работе пишем распределенное приложение, у которого сотни, если не тысячи настроек. Конфиги написаны на xml, расположены на разных хостах и должны быть согласованы друг с др...
Aleksandr Druzhinin
5
Всем привет 🙂 Какая-то непонятная проблема у меня с видео, раньше такого не было. Загружаю видео с гугл диска именно в видео mp4 и меняю ссылку как положено вот она: https://d...
Ксюша|Верстка на Тильде|Дизайн 🦥
6
средствами IBX как-то можно выполнить запрос insert ... returning?
Igor
31
Добрый день Хочу начать обучение языку, не являюсь представителем it, буду благодарна за помощь, совсем пока не понимаю ничего) Подскажите, пожалуйста, где можно начать первы...
Sara Lala
18
что это и почему оно? executor.start_polling(bot, skip_updates=True, on_startup=on_startup, File "/usr/local/lib/python3.10/dist-packages/aiogram/utils/executor.py", line 4...
𐌍𐌄 ᕓ𐌄𐌓𐌌Ꝋ𐌓𐌄
2
Hi there everyone Is there anyone who have not started hamster bot yet? I need only one, I'll be glad if you do this for me DM if you haven't yet
Mehrshad
53
Подскажите, почему в правом коде с1 дополняется до 8байт, а не до 4?
Sergey
9
Карта сайта