@testflightynoti · Post #37344 · 01.05.2026 г., 19:45
#Stance#Level#Up#Your#Activity Join the Stance: Level Up Your Activity beta on ✈️#TestFlight 🔗 Link: https://testflight.apple.com/join/nsGXh3FF Shared by Dimitri
TGINSIGHT SIMILAR POSTS
Изворен канал @pythonotes · Post #425 · 20 апр.
Недавно делал быстрый прототип асинхронного приложения в котором требовалось вызывать много синхронного кода. Да, я знаю, что это не лучший дизайн, но нужно было быстрое решение на один процесс и без очередей. Поэтому я выполнял код в потоках. Выглядело это примерно так: from fastapi.concurrency import run_in_threadpool async def execute(data: DataRequest) -> DataResponse: try: result = await run_in_threadpool(sync_function, data) return DataResponse(data=result) except Exception as e: return DataResponse( error=str(e), success=False, ) В общем работает нормально. Для всех вызовов под капотом используется общий тредпул, всё работает предсказуемо. Но потребовалось изменить количество запускаемых в пуле потоков (по умолчанию создается 40 воркеров). Так как дело происходит с FastAPI, делается это через lifespan используя настройки anyio: import anyio @asynccontextmanager async def lifespan(app: FastAPI): limiter = anyio.to_thread.current_default_thread_limiter() limiter.total_tokens = 100 yield # если вдруг нужно вернуть обратно limiter.total_tokens = 40 Зачем менять количество воркеров? - уменьшить, если оперативки мало (один тред занимает ~8мб) - увеличить чтобы выдержать нагрузку Если есть предложения получше при тех же вводных - предлагайте😉 #async
Hashtags
Пребарај: #level
@testflightynoti · Post #37344 · 01.05.2026 г., 19:45
#Stance#Level#Up#Your#Activity Join the Stance: Level Up Your Activity beta on ✈️#TestFlight 🔗 Link: https://testflight.apple.com/join/nsGXh3FF Shared by Dimitri
@swift_academy · Post #278 · 27.02.2026 г., 09:19
𝙱𝚎𝚐𝚒𝚗𝚗𝚎𝚛 > 𝙹𝚞𝚗𝚒𝚘𝚛 > 𝙼𝚒𝚍𝚍𝚕𝚎 > 𝙼𝚒𝚍𝚍𝚕𝚎+ > 𝚂𝚎𝚗𝚒𝚘𝚛 Har birimiz shu yo‘ldan o‘tganmiz, o'tmoqdamiz va yoki boshlaganmiz... Beginner: Eng ko'p kod yozadi. Xatolarni tushunishga harakat qiladi 'SI hamma narsa qiloladi' degan moodga tushib qolish ehtimoli katta 😄 Junior: Kodni ishlaydigan qilishni biladi. Logic yaxshilanadi Xatolardan yo o'sadi yoki tark etadi 😉 Lekin hali “clean code” refleks darajasida emas Middle: Ixcham va o‘qilishi oson kod yozadi Refactor qilishdan qo‘rqmaydi Bu yerda tafakkur o‘zgaradi: “Qanday ishlaydi?”dan > “Qanday yaxshiroq ishlaydi?”ga o‘ta boshlaydi. Middle - Doim o'rtada qolib ketish ehtimoli bor 🥱 Middle+: Qisqa kod yozish va Patternlarni ko‘rib boshlaydi “Buni umumlashtirish mumkin” deydi, ammo har doim ham emas 😉 Kod yozishdan ko'ta tizim ko‘rishni boshlaydi Bir funksiya emas, butun modul haqida o‘ylaydi Senior: Hozirgi vazifani emas, kelajakni ko‘radi Kod yozmaydi - arxitektura o‘ylaydi “Bugun ishlaydi” emas, “2 yildan keyin ham ishlaydi” deb yozadi Va eng qizig‘i: Senior eng kam kod yozadi 😄 Lekin eng ko‘p fikrlaydi. Xulosa: Beginner xatoni ko‘rmaydi Junior xatoni sezadi Middle xatoni tuzatadi Middle+ umumlashtiradi Senior kelajakdagi xatolarni oldini oladi MUHIM: Beginner, Junior va hatto Middle darajasida ham kodni avvalo o'zingiz yozing, SI esa faqat muhokama qilish & tushuntirish & o'rganish va tez izlanish uchun toki muammoni Proyekt darajasida ko'ra olish va yechimni tizimli shakllantira olish saviyasiga yetmaguncha. Batafsil: https://lnkd.in/dTyhYbpW Siz o‘zingizni qaysi bosqichda ko‘ryapsiz? #ios#swift#level#junior#middle#senior Mukhriddinbek Samidov 🔗YouTube | Instagram | LinkedIn | Telegram | Medium