Pipelining lähettää useita Redis-komentoja yhdessä verkon kierroksella sen sijaan, että odottaisit jokaisen komennon vastausta ennen seuraavan lähettämistä. Se parantaa throughput-suorituskykyä huomattavasti useiden komentojen lähettämisessä, koska verkon viive — ei Redis itse — on usein pullonkaula.
Ongelma: kierroksen viive
Normally each command is a request→reply round-trip:
send GET → wait for reply → send GET → wait for reply → ... (N × network latency)
→ Redis processes each command in microseconds, but each round-trip adds network
latency (e.g. 0.5ms). For 1000 commands, that's ~500ms JUST in waiting!
Pipelining: komentojen niputtaminen
pipeline = redis.();
( id userIds) pipeline.();
results = pipeline.();
