дергают колбэки. Мне нужна в корутине какая-то инфа из ближайшего события, я создаю фьючу, регистрирую временный колбэк, передаю ему фьючу и жду. Сработало условие, отпустило фьючу, я удалил колбэк и радостно продолжил. Как это можно переделать, чтобы обойтись без фьючи?
не понимаю, зачем тут asyncio
There must be a better way...
Само приложение преимущественно сетевыми запросами занимается и они могут быть довольно долгими, поэтому выбрана асинкио.
Наверняка, но я пока не увидел) Это я еще переделал, раньше было хуже
Сколько одновременно сетевых запросов обрабатывается (посылается или что там)? 100? 1000?
щас все спят, я завтра скажу, а то чет совсем смешная цифра получается))
так и зачем тогда asyncio тут? =)
Банально удобно как каркас приложения: 1. На каждую задачу, в т.ч. постоянно повторяющуюся, можно создать таску и контролировать ее работу (крон какой-нибудь здесь ультра лютый оверкилл), по надобности убить. 2. Можно вызвать что-нибудь через определенное время (рейт лимитеры удобно делать, например). 3. Не надо париться о гонках при доступе к каким-то мутабельным штукам. 4. Уже привычно, знакомо и большинство багов уже известно и избегаются. 5. Уже написан код, заточенный под приложухи с асинкио, делать еще и синхронную версию этого всего — максимально впадлу. Производительность не страдает, так как нагрузка смешная.
1. отдельные треды? 2. time.sleep? 3. надо. Тем более у тебя всё равно треды 4. должны быть привычны оба подхода 5. ты уже сделал синхронную версию кучи всего, перестань скрещивать ужа с ежом
У меня сейчас в районе 2700 тасок, боюсь представить, сколько бы жрали столько тредов (хотя, бо́льшая часть из них находится в состоянии сна и можно было бы их закрыть и заново запустить позже). Ежа с ужом я скрещиваю как исключение, это только в сервисе, собирающем стату процессов, в остальном я тредами только через тредпул пользуюсь, не дергая луп из других потоков.
Обсуждают сегодня