Rate limiting (token bucket / leaky bucket)
Kapcsolódó szolgáltatás Egyedi szoftverfejlesztés
MEGHATÁROZÁS
Korlátozza, hány hívást enged egy klienstől / kulcstól / IP-től egy időablakban. Két fő algoritmus: a token bucket fix ütemben tölt egy vödröt, a kérés egy tokent fogyaszt · burst-öt enged a kapacitásig. A leaky bucket fix ütemben enged kérést tovább, a többletet eldobja vagy queue-ba teszi · simább, kevésbé burst-barát. Produkcióban Redis-alapú (`INCR` + `EXPIRE` vagy Lua) vagy edge-en (Cloudflare, Vercel) implementálod. A 429-es válaszhoz mindig küldj `Retry-After` headert.
- Docker→
Egy app-ot a függőségeivel együtt egy image-be csomagolunk, amiből futtatható container indul - így mindenhol ugyanúgy fut, fejlesztői gépen és szerveren is. A „nálam működik” innentől nem kifogás.
- CI/CD→
Continuous Integration / Delivery: minden commitot automatikusan buildelünk, tesztelünk és (ha kéred) deployolunk. Ez a pipeline teszi lehetővé, hogy naponta sokszor, biztonságosan szállítsunk - kézi hibák nélkül.
- Blue-Green Deployment→
Két azonos környezetet futtatunk: a blue él, a green az új verzió. Ha a green leellenőrzött, átkapcsoljuk rá a forgalmat; baj esetén egy mozdulattal visszaváltunk. Zero-downtime release, azonnali rollback.
- Horizontális skálázás→
Több gépet/instance-ot adunk hozzá (scale out), nem egy nagyobbat (vertikális, scale up). Stateless szolgáltatásoknál ez a nyerő: olcsóbb, rugalmasabb, nincs felső plafon. State-et viszont külön tárba tesszük.
- Load balancer→
A bejövő forgalmat több instance között osztja szét - ez a bejárati ajtó, ami redundanciát és sima skálázást ad. Health checkekkel kiveszi a halott instance-okat, így egy gép kiesése nem látszik a felhasználónak.
- Distributed tracing→
Egy kérést végigkövetünk az összes szolgáltatáson egy trace ID-val (pl. OpenTelemetry). Microservice-rendszerben így derül ki másodpercek alatt, melyik szolgáltatás lassított be vagy hibázott - nem találgatunk.