Redis-パイプライン
RedisはTCPサーバーであり、要求/応答プロトコルをサポートしています。Redisでは、リクエストは次の手順で実行されます-
クライアントはサーバーにクエリを送信し、サーバーの応答を通常はブロックする方法でソケットから読み取ります。
サーバーはコマンドを処理し、応答をクライアントに送り返します。
パイプラインの意味
パイプライン化の基本的な意味は、クライアントが応答をまったく待たずにサーバーに複数の要求を送信し、最後に1つのステップで応答を読み取ることができるということです。
例
Redisパイプラインを確認するには、Redisインスタンスを起動し、ターミナルで次のコマンドを入力します。
$(echo -en "PING\r\n SET tutorial redis\r\nGET tutorial\r\nINCR
visitor\r\nINCR visitor\r\nINCR visitor\r\n"; sleep 10) | nc localhost 6379
+PONG
+OK
redis
:1
:2
:3
上記の例では、を使用してRedis接続を確認します PINGコマンド。名前の付いた文字列を設定しましたtutorial 価値のある redis。後で、そのキーの値を取得し、訪問者数を3回インクリメントします。その結果、すべてのコマンドがRedisに1回送信され、Redisがすべてのコマンドの出力を1つのステップで提供していることがわかります。
パイプラインの利点
この手法の利点は、プロトコルのパフォーマンスが大幅に向上することです。パイプライン化によって得られるスピードアップは、ローカルホストへの接続の5倍から、低速のインターネット接続での少なくとも100倍までの範囲です。