Сети и протоколы
Перехват прокси и шлюзы безопасности: rate limiter, WAF, mTLS
Ботнет отправляет 10 000 запросов в секунду с 10 000 разных IP. Ваш per-IP rate limiter видит 1 запрос с IP — хорошо ниже лимита. Ваш WAF видит легитимные браузерные fingerprints. Сервер origin вот-вот будет перегружен. Шлюзы безопасности работают, но работают в одиночку, а не в связке. Этот урок рассматривает каждый шлюз, его стоимость и почему ни один из них не работает без остальных.
Шлюз 1: Маршрутизация обратного прокси по состоянию health
До того как SYN-пакет Бэа достигает origin, он может прийти к Патти — обратному прокси или CDN edge. Патти принимает решение о маршрутизации:
Путь при попадании в кэш. Патти проверяет кэш: «Есть ли у меня ответ для этого URL с совпадающими заголовками Vary?» Если да, она отвечает немедленно из кэша edge. TCP + TLS были согласованы с edge-сервером Патти (~20 мс RTT); origin никогда не видит запрос.
Путь при промахе кэша. Патти проверяет состояние origin. Health checks выполняются вне основного потока каждые несколько секунд — периодический GET /health или TCP-зонд к каждому серверу origin. Если origin здоров, Патти перенаправляет. Если нездоров (неудачная проверка, процесс упал, высокая частота 5xx), Патти маршрутизирует к резервному серверу в пуле. Это происходит на лету — SYN, приходящий во время failover, может быть направлен к другому серверу.
Connection draining. При удалении сервера из пула (деплой, уменьшение масштаба) Патти прекращает отправлять новые соединения на него, но позволяет существующим завершить ответ. Окно draining (обычно 30–60 с) гарантирует чистое завершение запросов в полёте до отключения сервера.
| Шлюз | Задержка | Что блокирует | Что пропускает |
|---|---|---|---|
| Проверка кэша прокси | <1 мс | Кэшируемый трафик — обслуживает с edge | Некэшируемые, мутирующие endpoints |
| Per-IP rate limiter | <1 мс | Flood с одного IP, простые scrapers | Распределённые ботнеты (1 req/IP/s) |
| WAF сопоставление сигнатур | 1–5 мс | SQLi, XSS, CVE-сигнатуры | Новые атаки, зашифрованные полезные нагрузки |
| Проверка сертификата mTLS | 20–40 мс | Неаутентифицированные сервисы в service mesh | Компрометированный, но действительный владелец сертификата |
Шлюз 2: Rate limiter (token bucket)
Rate limiter устанавливает квоты: «Этот IP может отправить N запросов в секунду.» Реализация: алгоритм token bucket. У каждого IP есть корзина с ёмкостью C. Каждую секунду добавляется T токенов (до C). Каждый запрос потребляет один токен. Когда токены исчерпаны, новые запросы отбрасываются или возвращается 429 Too Many Requests.
Token bucket vs leaky bucket. Token bucket допускает всплески до ёмкости C. Leaky bucket вытекает с постоянной скоростью, предотвращая всплески. Большинство API rate limiter используют token bucket, потому что он допускает пакетных, но добросовестных клиентов (браузер, загружающий 30 подресурсов одновременно) без их наказания.
Проблема распределённого ботнета. Ботнет из 10 000 IP, каждый отправляет 0,9 req/s, отправляет суммарно 9 000 req/s. Лимит 2 req/s на IP пропускает их всех. Защита: добавить глобальный лимит одновременных соединений или адаптивное ограничение конкурентности на origin — когда количество запросов в полёте превышает мощность сервера, новые отклоняются быстрым 503 независимо от per-IP квоты.
Jitter при сбросе лимита. Если все клиенты одновременно достигают лимита и все токены сбрасываются в секунду 0, толпа бьёт по origin в t=1 с. Решение: рандомизировать смещения пополнения токенов на клиента (добавить ±10% jitter к окну пополнения). Сбросы лимита распределяются по клиентам, сглаживая нагрузку на origin.
Шлюз 3: WAF — Web Application Firewall
WAF проверяет контент на уровне приложения. Два режима:
На основе сигнатур (rule mode). OWASP ModSecurity Core Rule Set (CRS) определяет паттерны: SQL-инъекции (union select), XSS (<script>), path traversal (../), полезные нагрузки для конкретных CVE. Каждый запрос сопоставляется с сотнями правил. Работа на PL1–PL2 (Paranoia Level 1-2) балансирует ложные срабатывания и покрытие. PL4 (параноидальный) блокирует легитимный трафик, случайно совпадающий с агрессивными паттернами.
Аномальный. Базируется на нормальной форме запроса (скорость, user-agent, структура заголовков, энтропия нагрузки). Отклонения оцениваются. IP, отправляющий 100 req/min с fingerprint headless Chrome, который внезапно отправляет 3 000 req/min с идентичными заголовками, помечается как бот. Аномальное обнаружение нельзя обойти, зная правила.
Стоимость WAF. 1–5 мс на запрос для rule-based WAF на edge. Обоснование: устраняет широкие классы атак на уровне приложения, которые иначе потребовали бы дорогостоящих путей кода на уровне приложения или защиты запросов к БД.
Шлюз 4: mTLS — взаимная TLS для авторизации сервис-к-сервису
Обычный TLS аутентифицирует только сервер (Бэа доверяет Свену через сертификат Кары). mTLS аутентифицирует обе стороны. Во время TLS-рукопожатия Свен отправляет сообщение CertificateRequest. Бэа отправляет свой клиентский сертификат. Свен проверяет его против доверенного CA.
Где mTLS важен. Внутренние микросервисы в zero-trust сети. Если у вас есть payment service и user service в одном кластере Kubernetes, mTLS гарантирует, что user service не может имперсонировать payment service — даже если злоумышленник получает сетевой доступ внутри кластера.
SPIFFE. Фреймворк SPIFFE/SPIRE автоматизирует выдачу сертификатов для рабочих нагрузок: каждый сервис получает краткосрочный сертификат (SVID) от SPIFFE-сервера. Сертификаты ротируются автоматически (например, ежечасно). mTLS применяется service mesh (Istio, Linkerd) как sidecar proxy — код приложения не работает с TLS напрямую.
Стоимость mTLS. Один дополнительный round trip на новое соединение (запрос клиентского сертификата + отправка). 20–40 мс добавляется к задержке первого соединения. На тёплых соединениях (возобновление сессии) стоимость нулевая. Операционная стоимость: распределение, ротация и отзыв сертификатов должны быть автоматизированы — делать это вручную для сотен сервисов непрактично.
Граничные случаи
mTLS не защищает от скомпрометированного, но действительного владельца сертификата. Если злоумышленник крадёт действительный клиентский сертификат, mTLS им доверяет. Защита: короткий срок жизни сертификата (1 час через SPIFFE) + OCSP stapling для отзыва. Вероятность того, что злоумышленник перехватит и использует украденный сертификат до истечения его срока, резко падает, когда сертификаты живут всего час.
Проследите запрос от обычного пользователя и IP ботнета через все четыре шлюза.
Ботнет отправляет 1 запрос/секунду с 10 000 разных IP. Ваш per-IP лимит — 5 req/s. Как защититься, не блокируя легитимных пользователей?
Почему сертификаты mTLS должны быть краткосрочными (например, 1 час) в zero-trust service mesh?
- 01Что такое connection draining и зачем он нужен при rolling deploy?
- 02Почему добавление jitter к времени пополнения токенов rate limiter снижает пиковую нагрузку на origin?
- 03Что добавляет SPIFFE по сравнению с ручным управлением сертификатами mTLS?
До того как запрос достигает origin, он проходит четыре шлюза: поиск в кэше CDN (полностью устраняет запрос при кэш-попадании), per-IP rate limiter с token bucket (останавливает flood с одного IP), WAF с сопоставлением сигнатур (блокирует известные паттерны атак) и опциональную проверку клиентского сертификата mTLS (предотвращает неаутентифицированные вызовы сервис-к-сервису в zero-trust mesh). Каждый шлюз добавляет менее 5 мс, кроме mTLS (20–40 мс при первом соединении). Распределённые ботнеты обходят per-IP rate limiter, распределяя нагрузку — защита: глобальный адаптивный лимит конкурентности на origin, отклоняющий избыточные запросы в полёте быстрым 503 независимо от per-IP квоты. SPIFFE автоматизирует выдачу и ротацию сертификатов mTLS, делая краткосрочные ежечасные сертификаты операционально практичными для сотен микросервисов.
встречается в258
- Почему GraphQL получает N+1junior
- Механика DataLoader: батчинг на границе тикаmiddle
- Контракты batch-функции: порядок, формы, ошибкиmiddle
- Federation и lookahead: батчинг за пределами DataLoadermiddle
- Защита сложности запросов: depth, cost, persisted queriesmiddle
- Senior GraphQL API: scheduling-контракт, изоляция арендаторов, наблюдаемостьsenior
- Путь запроса: семь остановок от сокета до ответаjunior
- Accept и парсинг: от очереди ядра до типизированного запросаmiddle
- Маршрутизация и middleware: что выполняется и в каком порядкеmiddle
- Обработчик и ответ: от бизнес-логики до байтов на проводеmiddle
- Стриминг и backpressure: когда клиент читает медленнее, чем вы пишетеsenior
- Таймауты и хвостовая задержка: бюджеты, дедлайны и ловушка fan-outsenior
- Middleware и DI: два паттерна, формирующие любой backendjunior
- Пишем middleware: сигнатуры, next() и три модели фреймворковmiddle
- Инверсия управления: как зависимости добираются до классаmiddle
- Скоупы и время жизни DI: singleton, request, transientmiddle
- DI как шов для тестов: фейки, моки и граница, которая важнаsenior
- DI-контейнеры в продакшене: графы разрешения, циклы и когда не стоитsenior
- Блокирующий vs неблокирующий I/O: два способа ждатьjunior
- Event loop: один поток, упорядоченные фазыmiddle
- Что блокирует цикл: CPU-работа и синхронные вызовыmiddle
- Вынос CPU-работы: worker threads и пул libuvmiddle
- Backpressure и ограниченная конкурентностьsenior
- Пропускная способность под нагрузкой: хвостовая задержка и насыщениеsenior
- Зачем пул: цена создания соединенияjunior
- Размер пула: почему больше не значит быстрееmiddle
- Взятие и таймауты: очередь ожидания — настоящий дроссель задержкиmiddle
- Зачем идемпотентность: безопасные retryjunior
- Серверный state machine: четыре состояния idempotency keymiddle
- Стратегии retry: backoff, jitter и thundering herdmiddle
- Outbox и inbox: effectively-once через dual-write границуmiddle
- Конкурентность и архитектура кеша для идемпотентности на масштабеsenior
- Наблюдаемость, production-инциденты и дизайн для глобального масштабаsenior
- Event loop: один поток, три очередиjunior
- Задачи, микрозадачи и scheduler.yield()middle
- Точность таймеров, троттлинг и фоновая работаmiddle
- Голодание микрозадач, длинные задачи и LoAFsenior
- Event loop Node.js: фазы, nextTick и задержка циклаsenior
- React, Vue и наблюдаемость INP в продакшенеsenior
- Render pipeline: шесть стадий от байтов до пикселейjunior
- Цена стадий и модель процесса рендерераmiddle
- Инвалидация, dirty-биты и containmiddle
- Слои композитора: продвижение, перекрытие и память GPUmiddle
- Флейм-стрип DevTools и жизненный цикл кадраmiddle
- Layout thrash: форсированная синхронная компоновкаsenior
- BeginMainFrame, анимации на потоке compositor и память GPUsenior
- Observability в проде: LoAF, INP и полная поверхность атакиsenior
- Что такое V8 и почему производительность различается в 100 разjunior
- Четырёхуровневый JIT-конвейер V8 и профилированная тиеризацияmiddle
- Hidden classes, деревья переходов и расположение в памятиmiddle
- Inline caches, состояния IC и деоптимизацияmiddle
- Orinoco GC: параллельный scavenger, конкурентная разметка и барьеры записиmiddle
- Спекулятивный движок TurboFan и ловушка deopt-loopsenior
- V8 в production: Isolates, сжатие указателей и реальные аварииsenior
- Жизненный цикл service worker и стратегии кешированияmiddle
- Граничные случаи service worker: version skew, долговременность и ловушка навигацииsenior
- Что делает реконсилер: render vs commitjunior
- Объект fiber и дерево с двойной буферизациейmiddle
- Чистота фазы render и подшаги фазы commitmiddle
- Реконсиляция: эвристики диффа и ловушка ключейmiddle
- Приоритетные lanes, time-slicing и useTransitionmiddle
- Bailout, мемоизация и tearingsenior
- React Profiler, компилятор и продакшн-наблюдаемостьsenior
- Стратегии рендеринга: SSG, SSR, ISR, streaming и гидратацияjunior
- SSG, SSR, ISR, streaming и RSC — как работает каждая стратегияmiddle
- Цена гидратации: selective, progressive, острова, resumabilitymiddle
- Hydration mismatch: причины, обнаружение и правило детерминизмаsenior
- RSC, стратегия на маршрут и production-наблюдаемостьsenior
- Core Web Vitals: что измеряют LCP, INP и CLSjunior
- LCP: четыре фазы, одна доминирующая стоимостьmiddle
- INP: input delay, processing, presentationmiddle
- CLS: почему происходят сдвиги лейаута и как их остановитьmiddle
- Lab vs field: почему они расходятся и как использовать каждыйmiddle
- Трейдоффы метрик, RUM-атрибуция и цикл CI+полеsenior
- Общая картина: от URL до LCP до INP как эстафетаjunior
- Восемь слоёв трассировки: от service worker до второй навигацииmiddle
- Пять канонических поломок: где производство стабильно ломаетсяsenior
- Метод трёх треков: чтение трасс и построение системы мониторингаsenior
- Что такое cache stampede и почему он делает всё хужеjunior
- Лок и single-flight: ограничение параллельных rebuildmiddle
- XFetch: вероятностное раннее истечение без координацииmiddle
- Stale-while-revalidate и CDN request coalescingmiddle
- Детектирование stampede и дизайн TTL для продакшенаmiddle
- Метастабильный сбой, fencing-токены и production-постмортемыsenior
- Что такое отношение: таблицы, строки, ключи и ограниченияjunior
- Ограничения, ключи и типы данных Postgresmiddle
- Нормальные формы, денормализация и почему схемы «прилипают»middle
- JSONB, массивы и когда side table побеждаетmiddle
- Heap-хранилище, TOAST и выравнивание колонокsenior
- Целостность схемы: deferral, версионирование и сбои в продакшнеsenior
- Реляционная модель vs документные, wide-column, граф и key-valuesenior
- Что такое индекс и как он ускоряет запросыjunior
- Leading-column rule: почему порядок столбцов в composite-индексе важенmiddle
- Partial, expression и covering-индексыmiddle
- Типы индексов: GIN, GiST, BRIN, Hash, Bloom и HOT-обновленияmiddle
- Index-only scan, Visibility Map и INCLUDEsenior
- Типичные сбои в продакшне и аудит индексовsenior
- Упражнение по проектированию индексов: стратегия полнотекстового поискаsenior
- EXPLAIN и планы выполнения: что решает планировщик и почемуjunior
- Типы сканирования: Seq, Index, Bitmap, Index-Onlymiddle
- Алгоритмы соединения и каскад ошибок оценки строкmiddle
- pg_statistic, ANALYZE и производственная наблюдаемостьmiddle
- Расширенная статистика: исправление ошибок оценки для коррелированных колонокsenior
- Кеш планов, настройка константных стоимостей и внутренности планировщикаsenior
- Производственные режимы отказа и стабильность плановsenior
- MVCC: как Postgres раздаёт согласованные снимкиjunior
- Заголовок tuple и механика снимковmiddle
- HOT-обновления и уровни изоляцииmiddle
- VACUUM, bloat и autovacuummiddle
- CLOG, XID wraparound и MultiXactsenior
- SSI и production-тюнинг autovacuumsenior
- Реальные провалы MVCC, deployment-паттерны и распределённые снимкиsenior
- Connection pool: зачем амортизировать стоимость backend Postgresjunior
- Режимы PgBouncer: session, transaction и statementmiddle
- Размер пула: формула (ядра × 2) + шпинделей и двухуровневый стекmiddle
- Исчерпание пула и idle-in-transaction: сценарий отказа в 3 ночиmiddle
- Миграция на transaction mode: план развёртывания и prepared statements в PgBouncer 1.21middle
- Процессная модель Postgres и почему увеличение max_connections снижает производительностьsenior
- Ландшафт пулеров 2026, serverless connection storms и полная таксономия отказовsenior
- Что такое миграция схемы и почему она заменяет ad-hoc DDLjunior
- ADD COLUMN: мгновенно в PG 11+ против перезаписи в старом Postgresjunior
- Режим отказа очереди блокировок: почему мгновенный DDL может заморозить базуmiddle
- Безопасные DDL-паттерны: NOT VALID, CONCURRENTLY и исправления небезопасных операцийmiddle
- Expand-contract: нулевой простой для ломающих изменений схемыmiddle
- Advisory-блокировки, инструменты миграций и координация деплояsenior
- Таксономия сбоев миграций и дисциплина продакшнаsenior
- Зачем нужно шардирование: потолок одного Postgresjunior
- Выбор ключа шарда: стратегии hash, range, list и directorymiddle
- Партиционирование против шардирования: одно слово, два разных понятияmiddle
- Ко-локация и Citus: инвариант, делающий шардирование пригодным к использованиюmiddle
- Режим отказа hot shard: обнаружение, изоляция и долгосрочная политикаmiddle
- Schema-based шардирование и альтернативы мультиарендностиsenior
- Онлайн-решардинг, 2PC и операционная стоимость шардированияsenior
- Семь актов: от CREATE TABLE до Citusjunior
- Акты 1–3 в глубину: схема, индексы и статистика планировщикаmiddle
- Акты 4–6 в глубину: MVCC bloat, connection pooling и безопасные миграцииmiddle
- Акт 7 в глубину: шардинг, co-location и семиуровневый каскад трейдоффовmiddle
- Наблюдаемость, антипаттерны и производственный триажsenior
- Роли Raft, term и почему majority-кворум предотвращает split brainjunior
- Как Raft реплицирует log entry и решает, что его безопасно коммититьmiddle
- Выборы лидера в Raft: таймауты, правила голосования и четыре свойства безопасностиmiddle
- Raft в реальном мире: partition, медленный диск и клиентская маршрутизацияmiddle
- Расширения Raft: pre-vote, learner, snapshot и линеаризуемые чтенияsenior
- Raft в production: membership change, Multi-Raft и observabilitysenior
- Где происходит data fetching — и почему это решает LCPjunior
- Fetch waterfall''''ы — диагностика и лечение через Promise.allmiddle
- React Server Components и Suspense streamingmiddle
- Клиентский кэш: TanStack Query, SWR и stale-while-revalidatemiddle
- LCP, prefetch и race conditions в интерактивном fetchingmiddle
- Senior internals: RSC payload, слои кэша и production паденияsenior
- Что такое три сигнала: метрики, логи, трейсыjunior
- Метрики и cardinality: cost-модель time-series databasemiddle
- Логи и объём: cost-модель структурного логированияmiddle
- Трейсы и сэмплирование: cost-модель distributed tracingmiddle
- Join-ключи и exemplar''''ы: как три сигнала становятся компонуемымиmiddle
- Observability 2.0: широкие события и сдвиг стоимостиsenior
- Режимы сбоя и инженерная практика: cardinality budget''''ы, PII и сэмплированиеsenior
- Зачем нужны структурные логи: дневник против таблицыjunior
- Схема продакшн-лога: поля, которые несёт каждая строкаmiddle
- Log levels и маршрутизация алертовmiddle
- Стратегии sampling и стоимость логовmiddle
- PII-редакция и log injectionsenior
- Propagation trace-контекста в логахsenior
- OTel Logs Data Model и audit-логи как подсистемаsenior
- Сигналы OTel, Semantic Conventions и проводной формат OTLPmiddle
- Авто-инструментирование и ручные спаны: правило 80/20 в OTelmiddle
- Collector OTel: receivers, processors, exporters и паттерны развёртыванияmiddle
- Стратегии сэмплирования: head, tail и parent-basedmiddle
- Vendor-нейтральность, eBPF-инструментирование, Operator и OTel в браузере и serverlesssenior
- Эксплуатация OTel Collector: надёжность, version skew, режимы отказа и управлениеsenior
- RED и USE: два чек-листа, одна дисциплина триажаjunior
- Инструментация RED в Prometheus: счётчики, гистограммы и дисциплина cardinalitymiddle
- USE на Linux: CPU, память, диск, сеть и PSImiddle
- Golden signals, структура дашборда и auto-RED в service meshmiddle
- Cardinality как драйвер затрат: label, PII, exemplars и семплированиеmiddle
- Native histograms, SLO и паттерны production-сбоевmiddle
- SLI, SLO и error budget: надёжность в числахjunior
- Выбор SLI и SLO-целей: отношения, не ощущенияmiddle
- Multi-window multi-burn-rate-алертинг: почему AND лучше ORmiddle
- Error budget policy, latency SLO и составные journeysmiddle
- Iceberg SLI, математика составного SLO и SLA vs SLOsenior
- Продакшн-отказы SLO, самонаблюдаемость, безопасность и общая картинаsenior
- Flame graph: читаем картинку, которая показывает, куда ушло времяjunior
- Sampling vs instrumentation profiling: почему 99 Гц побеждает в productionmiddle
- Типы профилей: CPU, память, off-CPU, mutex — какой когда братьmiddle
- Continuous profiling: always-on flame graphs с eBPF и корреляцией trace-idmiddle
- Как flame graph строится из сэмплов и как использовать его в productionmiddle
- Linux perf, внутренности eBPF, PGO и ограничения sampling''''аsenior
- Profiling в production: безопасность, war stories, OTel profiles и дизайн инфраструктурыsenior
- Debugging-воронка: SLO → RED → trace → profilejunior
- Архитектура OTel: один SDK, четыре сигнала, один wire-форматmiddle
- Экономия на observability: удерживаем затраты в пределах 5% inframiddle
- Петля инцидента: от пейджера до постмортема до предотвращенияmiddle
- Масштаб, безопасность и ROI наблюдаемых системsenior
- Сначала профиль: измерь куда реально уходит времяjunior
- Закон Амдала и self-time: потолок любого ускорения, которое ты можешь выпуститьmiddle
- Измерительный цикл: микробенч, макробенч, prod-профиль, эффект наблюдателяmiddle
- Чтение флейм-графов: формы, профайлеры по языкам и 60-секундный сканmiddle
- Статистические baseline''''ы: почему один запуск — не измерениеmiddle
- История профайлеров и ловушки микробенчей: от Кнута до GWPsenior
- Hardware counters, профили холодного старта и безопасность профилейsenior
- Непрерывное профилирование в масштабе: затраты, CI-гейты, корреляция с трейсами и антипаттерныsenior
- Что делает путь горячим: симптом против причиныjunior
- Пять форм hotspot''''а: CPU, аллокации, кэш, лок, syscallmiddle
- Чтение parent и child chains: где применять правкуmiddle
- JIT deopt, цикл fix-and-verify и PR-time профилированиеmiddle
- Аппаратные счётчики и Intel TMA: диагностика подкатегорийsenior
- False sharing и горячие пути нативных мостовsenior
- Горячие пути в production: безопасность, хвостовая латентность и происхождение инструментовsenior
- Иерархия памяти: почему расстояние важнее числа операцийjunior
- Row-major vs column-major: порядок доступа и разрыв в 9xjunior
- Cache lines и false sharing: когда параллелизм замедляет кодmiddle
- Branch prediction: 10–30 циклов штрафа за неожиданный ifmiddle
- SIMD и data layout: AoS vs SoA и разница в 4–8xmiddle
- Hardware prefetcher, TLB и memory-level parallelismsenior
- Cache-oblivious алгоритмы, PGO и production failuressenior
- Основы GC: за что рантайм берёт налогjunior
- Алгоритмы GC: поколенческая гипотеза, concurrent marking и write barriermiddle
- GC tradeoffs: пауза, throughput, память и давление аллокацийmiddle
- Настройка GC: пейсинг, форма кучи и наблюдаемость аллокацийmiddle
- Внутреннее устройство GC: tri-color инвариант, write barriers и глубокое погружение в рантаймыsenior
- GC в production: наблюдаемость, безопасность, edge cases и управление флотомsenior
- N+1: одна логическая операция, много round-trip''''овjunior
- Семейства фиксов: JOIN, IN, preload и DataLoadermiddle
- Обнаружение N+1: query logs, APM traces и CI gatesmiddle
- DataLoader: батчинг по дереву резолверовmiddle
- Кросс-протокольный N+1: HTTP fan-out и Redis MGETmiddle
- N+1 в масштабе: исчерпание пула, изменения планов и денормализацияsenior
- Batching: амортизируй фиксированную цену каждой операцииjunior
- Окно батчинга: размер и время ожиданияmiddle
- Batching в Kafka и Postgresmiddle
- io_uring и наблюдаемость пакетированияmiddle
- От Nagle до io_uring: эволюция пакетированияmiddle
- Backpressure, изоляция сбоев и безопасность батчей в продакшенеsenior
- Что на самом деле стоит bundle: download, parse, compile, executejunior
- Core Web Vitals: LCP, INP и CLSmiddle
- Code splitting: route-level, component-level, vendor splittingmiddle
- Tree shaking и compression: удаляем то, что не используемmiddle
- Third-party scripts: тихий убийца бюджетаmiddle
- CI enforcement и RUM: делаем бюджеты рабочимиmiddle
- V8 JIT-пайплайн, HTTP-приоритеты и безопасность bundlesenior
- Цикл performance: дисциплина, а не проектjunior
- Классификация и исправление: сопоставление family bottleneck с методамиmiddle
- Observability-стек и CI gates: ловить регрессии до выпускаmiddle
- От инцидента к enforcement: SLO burn до верифицированного исправления за 35 минутmiddle
- Культура, экономика и масштаб performancesenior
- At-most-once, at-least-once, exactly-once: три контракта доставкиjunior
- Три ножки сбоя — где реально происходят дубликаты и потериmiddle
- Consumer-side dedup: самый дешёвый путь к exactly-once processingmiddle
- Kafka exactly-once semantics: idempotent producer и транзакцииmiddle
- SQS visibility timeout, DLQ и outbox patternmiddle
- Exactly-once в production: impossibility-доказательство, гибридные паттерны и реальные инцидентыsenior
- Что такое OAuth и почему пароли — не ответjunior
- Authorization code flow с PKCEmiddle
- Валидация ID-токена и управление JWKS-кешемmiddle
- Ротация refresh-токенов и scope-based least privilegemiddle
- Sender-constrained токены: DPoP и mTLSsenior
- OAuth в production: audience атаки, observability и реальные провалыsenior