Pipelining отправляет несколько команд Redis в одной сетевой транзакции вместо ожидания ответа на каждую команду перед отправкой следующей. Это драматически улучшает пропускную способность при выполнении множества команд, потому что сетевая задержка — а не сам Redis — часто является узким местом.
Проблема: задержка при передаче
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: пакетная обработка команд
pipeline = redis.();
( id userIds) pipeline.();
results = pipeline.();
