Redisコマンドラインツールの使用方法
Jun 03, 2023 am 08:53 AM単一のコマンドを実行する
通常、Redis サーバーにアクセスするときは、redis-cli を使用して対話モードに入り、質問と応答によってサーバーの読み取りと書き込みを行います。その「インタラクティブ」モデル」。もう 1 つの「ダイレクト モード」があります。これは、コマンド パラメーターを redis-cli に直接渡すことによってコマンドを実行し、出力結果を取得します。
$ redis-cli incrby foo 5<br/>(integer) 5<br/>$ redis-cli incrby foo 5<br/>(integer) 10<br/>
出力コンテンツが大きい場合は、出力を外部ファイルにリダイレクトすることもできます
$ redis-cli info > info.txt<br/>$ wc -l info.txt<br/> 120 info.txt<br/>
上記のコマンドが指すサーバーは、デフォルトのサーバー アドレスです. If you want to point 特定のサーバーはこのようなバッチでコマンドを実行できます
// -n 2 表示使用第2个库,相当于 select 2<br/>$ redis-cli -h localhost -p 6379 -n 2 ping<br/>PONG<br/>
日々のオンライン開発プロセスでは、データを手動で作成して Redis にインポートすることが避けられない場合があります。通常、これを行うためのスクリプトを作成します。ただし、別のより便利な方法があります。それは、redis-cli を直接使用して一連の命令をバッチで実行することです。
$ cat cmds.txt<br/>set foo1 bar1<br/>set foo2 bar2<br/>set foo3 bar3<br/>......<br/>$ cat cmds.txt | redis-cli<br/>OK<br/>OK<br/>OK<br/>...<br/>
$ redis-cli < cmds.txt<br/>OK<br/>OK<br/>OK<br/>...<br/>
set multi-line string
文字列に複数の行があり、それを set コマンドに渡したい場合、redis-cli はどのように行うのでしょうか? -x オプションを使用すると、標準入力の内容が最後の引数として使用されます。
$ cat str.txt<br/>Ernest Hemingway once wrote,<br/>"The world is a fine place and worth fighting for."<br/>I agree with the second part.<br/>$ redis-cli -x set foo < str.txt<br/>OK<br/>$ redis-cli get foo<br/>"Ernest Hemingway once wrote,\n\"The world is a fine place and worth fighting for.\"\nI agree with the second part.\n"<br/>
命令の繰り返し実行
redis-cli は、命令の複数回の繰り返し実行もサポートしています。各命令の実行間隔を設定すると、特定の命令の出力内容を観察できます。時間をかけて指導します。
// 间隔1s,执行5次,观察qps的变化<br/>$ redis-cli -r 5 -i 1 info | grep ops<br/>instantaneous_ops_per_sec:43469<br/>instantaneous_ops_per_sec:47460<br/>instantaneous_ops_per_sec:47699<br/>instantaneous_ops_per_sec:46434<br/>instantaneous_ops_per_sec:47216<br/>
127.0.0.1:6379> 5 ping<br/>PONG<br/>PONG<br/>PONG<br/>PONG<br/>PONG<br/># 下面的指令很可怕,你的屏幕要愤怒了<br/>127.0.0.1:6379> 10000 info<br/>.......<br/>
Export csv
Redis データベース全体を実行することはできませんが、 CSV形式にエクスポートする場合は、単一項目をエクスポートできます。コマンドの結果はCSV形式で出力されます。
$ redis-cli rpush lfoo a b c d e f g<br/>(integer) 7<br/>$ redis-cli --csv lrange lfoo 0 -1<br/>"a","b","c","d","e","f","g"<br/>$ redis-cli hmset hfoo a 1 b 2 c 3 d 4<br/>OK<br/>$ redis-cli --csv hgetall hfoo<br/>"a","1","b","2","c","3","d","4"<br/>
$ redis-cli --csv -r 5 hgetall hfoo<br/>"a","1","b","2","c","3","d","4"<br/>"a","1","b","2","c","3","d","4"<br/>"a","1","b","2","c","3","d","4"<br/>"a","1","b","2","c","3","d","4"<br/>"a","1","b","2","c","3","d","4"<br/>
これを見た読者は、--csv パラメータの効果は、出力を一度変換してカンマで区切るだけであり、それ以上のものではないことを理解するはずです。
lua スクリプトの実行
lua スクリプト セクションでは、eval 命令を使用してスクリプト文字列を実行します。毎回、スクリプトの内容を 1 行の文字列に圧縮してから、 eval 命令は非常に面倒で、可読性も非常に悪いです。 redis-cli はこれを考慮して、スクリプト ファイルを直接実行できます。
127.0.0.1:6379> eval "return redis.pcall('mset', KEYS[1], ARGV[1], KEYS[2], ARGV[2])" 2 foo1 foo2 bar1 bar2<br/>OK<br/>127.0.0.1:6379> eval "return redis.pcall('mget', KEYS[1], KEYS[2])" 2 foo1 foo2<br/>1) "bar1"<br/>2) "bar2"<br/>
$ cat mset.txt<br/>return redis.pcall('mset', KEYS[1], ARGV[1], KEYS[2], ARGV[2])<br/>$ cat mget.txt<br/>return redis.pcall('mget', KEYS[1], KEYS[2])<br/>$ redis-cli --eval mset.txt foo1 foo2 , bar1 bar2<br/>OK<br/>$ redis-cli --eval mget.txt foo1 foo2<br/>1) "bar1"<br/>2) "bar2"<br/>
lua スクリプトが長すぎる場合は、--eval が役立ちます。
サーバーのステータスを監視する
--stat パラメーターを使用してサーバーのステータスをリアルタイムで監視し、1 秒ごとにリアルタイムで出力できます。
$ redis-cli --stat<br/>------- data ------ --------------------- load -------------------- - child -<br/>keys mem clients blocked requests connections<br/>2 6.66M 100 0 11591628 (+0) 335<br/>2 6.66M 100 0 11653169 (+61541) 335<br/>2 6.66M 100 0 11706550 (+53381) 335<br/>2 6.54M 100 0 11758831 (+52281) 335<br/>2 6.66M 100 0 11803132 (+44301) 335<br/>2 6.66M 100 0 11854183 (+51051) 335<br/>
大きなキーをスキャン
この機能は非常に実用的で、オンラインで何度も試しました。 Redis で時折発生する遅延の問題に遭遇するたびに、インスタンスに大きな KEY があるかどうかが最初に思い浮かびますが、メモリの拡張と大きな KEY の解放により、メイン スレッドの遅延が発生します。中に大きなKEYがあるかどうかがわかれば、それをスキャンするプログラムを自分で書くこともできますが、これは面倒すぎます。 redis-cli は、メモリ内の大きな KEY をすばやくスキャンするための --bigkeys パラメータを提供します。スキャン コマンドによってサーバーの ops アラームが突然増加することを避けるために、-i パラメータを使用してスキャン間隔を制御します。
$ ./redis-cli --bigkeys -i 0.01<br/># Scanning the entire keyspace to find biggest keys as well as<br/># average sizes per key type. You can use -i 0.1 to sleep 0.1 sec<br/># per 100 SCAN commands (not usually needed).<br/><br/>[00.00%] Biggest zset found so far 'hist:aht:main:async_finish:20180425:17' with 1440 members<br/>[00.00%] Biggest zset found so far 'hist:qps:async:authorize:20170311:27' with 2465 members<br/>[00.00%] Biggest hash found so far 'job:counters:6ya9ypu6ckcl' with 3 fields<br/>[00.01%] Biggest string found so far 'rt:aht:main:device_online:68:{-4}' with 4 bytes<br/>[00.01%] Biggest zset found so far 'machine:load:20180709' with 2879 members<br/>[00.02%] Biggest string found so far '6y6fze8kj7cy:{-7}' with 90 bytes<br/>
サンプリング サーバーの手順
現在、OPS が高すぎる Redis サーバーがオンラインにあります。多くのビジネス モジュールがこの Redis を使用しています。どのビジネスが異常に高い OPS を引き起こしているのかを特定するにはどうすればよいですか?このとき、オンラインサーバーの命令をサンプリングすることができ、それを観察することでOPSの割合が高い業務ポイントを大まかに分析することができます。サーバーによって実行されたすべての命令を一度に表示するには、monitor コマンドを使用します。なお、使用する際は強制的に中断したい場合でもCtrl Cを押さないとディスプレイに指示が多すぎて一瞬でパチパチになってしまいます。
$ redis-cli --host 192.168.x.x --port 6379 monitor<br/>1539853410.458483 [0 10.100.90.62:34365] "GET" "6yax3eb6etq8:{-7}"<br/>1539853410.459212 [0 10.100.90.61:56659] "PFADD" "growth:dau:20181018" "2klxkimass8w"<br/>1539853410.462938 [0 10.100.90.62:20681] "GET" "6yax3eb6etq8:{-7}"<br/>1539853410.467231 [0 10.100.90.61:40277] "PFADD" "growth:dau:20181018" "2kei0to86ps1"<br/>1539853410.470319 [0 10.100.90.62:34365] "GET" "6yax3eb6etq8:{-7}"<br/>1539853410.473927 [0 10.100.90.61:58128] "GET" "6yax3eb6etq8:{-7}"<br/>1539853410.475712 [0 10.100.90.61:40277] "PFADD" "growth:dau:20181018" "2km8sqhlefpc"<br/>1539853410.477053 [0 10.100.90.62:61292] "GET" "6yax3eb6etq8:{-7}"<br/>
诊断服务器时延
通常我们使用Unix的ping命令来测量两台计算机的延迟。Redis 也提供了时延诊断指令,不过它的原理不太一样,它是诊断当前机器和 Redis 服务器之间的指令(PING指令)时延,它不仅仅是物理网络的时延,还和当前的 Redis 主线程是否忙碌有关。如果你发现 Unix 的 ping 指令时延很小,而 Redis 的时延很大,那说明 Redis 服务器在执行指令时有微弱卡顿。
$ redis-cli --host 192.168.x.x --port 6379 --latency<br/>min: 0, max: 5, avg: 0.08 (305 samples)<br/>
时延单位是 ms。redis-cli 还能显示时延的分布情况,而且是图形化输出。
$ redis-cli --latency-dist<br/>
这个图形的含义作者没有描述,读者们可以尝试破解一下。
远程 rdb 备份
执行下面的命令就可以将远程的 Redis 实例备份到本地机器,远程服务器会执行一次bgsave操作,然后将 rdb 文件传输到客户端。远程 rdb 备份让我们有一种“秀才不出门,全知天下事”的感觉。
$ ./redis-cli --host 192.168.x.x --port 6379 --rdb ./user.rdb<br/>SYNC sent to master, writing 2501265095 bytes to './user.rdb'<br/>Transfer finished with success.<br/>
模拟从库
如果你想观察主从服务器之间都同步了那些数据,可以使用 redis-cli 模拟从库。
$ ./redis-cli --host 192.168.x.x --port 6379 --slave<br/>SYNC with master, discarding 51778306 bytes of bulk transfer...<br/>SYNC done. Logging commands from master.<br/>...<br/>
从库连上主库的第一件事是全量同步,所以看到上面的指令卡顿这很正常,待首次全量同步完成后,就会输出增量的 aof 日志。
以上がRedisコマンドラインツールの使用方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

人気の記事

人気の記事

ホットな記事タグ

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Windows 11 10.0.22000.100 のインストール時の 0x80242008 エラーの解決策

erlang と golang ではどちらのパフォーマンスが優れていますか?
