1.3. redis-cli - Command-line client to redis-server
1.3.1. 命令参数
1.3.1.1. password
-a <password> Password to use when connecting to the server. [root@netkiller conf.d]# redis-cli -a hsM8NK8b71vFQKFOS55jbWJrA1TYgI4e
1.3.1.2. raw
--raw Use raw formatting for replies (default when STDOUT is not a tty).
有时显示这样的数据
[hadoop@netkiller ~]$ redis-cli 127.0.0.1:6379> ZREVRANGE FASTNEWS_DATA_STORE_KEY 0 1 1) "{\"title\":\"\xe4\xb8\x8a\xe8\xaf\x81\xe7\xbb\xbc\xe6\x8c\x87\xe5\x91\xa8\xe7\xba\xbf\xe4\xba\x94\xe8\xbf\x9e\xe9\x98\xb3\xef\xbc\x8c\xe5\x88\x9b\xe4\xb8\x9a\xe6\x9d\xbf\xe8\xbf\x9e\xe7\xbb\xad\xe4\xb8\xa4\xe5\x91\xa8\xe5\xa4\xa7\xe8\xb7\x8c\xef\xbc\x9b \xe4\xb8\x8a\xe8\xaf\x81\xe7\xbb\xbc\xe6\x8c\x87\xe5\x91\xa8\xe4\xba\x94\xe6\x94\xb6\xe7\x9b\x98\xe8\xb7\x8c0.23%\xef\xbc\x8c\xe4\xb8\x8b\xe8\xb7\x8c7.60\xe7\x82\xb9\xef\xbc\x8c\xe6\x8a\xa53237.98\xe7\x82\xb9\xef\xbc\x9b \xe6\xb7\xb1\xe8\xaf\x81\xe6\x88\x90\xe6\x8c\x87\xe5\x91\xa8\xe4\xba\x94\xe6\x94\xb6\xe7\x9b\x98\xe8\xb7\x8c0.03%\xef\xbc\x8c\xe4\xb8\x8b\xe8\xb7\x8c3.50\xe7\x82\xb9\xef\xbc\x8c\xe6\x8a\xa510363.48\xe7\x82\xb9\xef\xbc\x9b \xe6\xb2\xaa\xe6\xb7\xb1300\xe8\x82\xa1\xe6\x8c\x87\xe5\x91\xa8\xe4\xba\x94\xe6\x94\xb6\xe7\x9b\x98\xe8\xb7\x8c0.52%\xef\xbc\x8c\xe4\xb8\x8b\xe8\xb7\x8c19.49\xe7\x82\xb9\xef\xbc\x8c\xe6\x8a\xa53728.39\xe7\x82\xb9\xef\xbc\x9b \xe5\x88\x9b\xe4\xb8\x9a\xe6\x9d\xbf\xe6\x8c\x87\xe6\x95\xb0\xe5\x91\xa8\xe4\xba\x94\xe6\x94\xb6\xe7\x9b\x98\xe6\xb6\xa80.08%\xef\xbc\x8c\xe4\xb8\x8a\xe6\xb6\xa81.31\xe7\x82\xb9\xef\xbc\x8c\xe6\x8a\xa51689.92\xe7\x82\xb9\\r\\n\"}" 2) "{\"title\":\"\xe4\xb8\x8a\xe8\xaf\x81\xe7\xbb\xbc\xe6\x8c\x87\xe5\x91\xa8\xe4\xba\x94\xe6\x94\xb6\xe7\x9b\x98\xe4\xb8\x8b\xe8\xb7\x8c0.21%\xef\xbc\x8c\xe6\x8a\xa53237.98\xe7\x82\xb9\xef\xbc\x9b\xe6\xb7\xb1\xe8\xaf\x81\xe6\x88\x90\xe6\x8c\x87\xe5\x91\xa8\xe4\xba\x94\xe6\x94\xb6\xe7\x9b\x98\xe5\xbe\xae\xe8\xb7\x8c0.02%\xef\xbc\x8c\xe6\x8a\xa510364.82\xe7\x82\xb9\xef\xbc\x9b\xe5\x88\x9b\xe4\xb8\x9a\xe6\x9d\xbf\xe6\x8c\x87\xe6\x95\xb0\xe5\x91\xa8\xe4\xba\x94\xe6\x94\xb6\xe7\x9b\x98\xe5\xbe\xae\xe6\xb6\xa80.09%\xef\xbc\x8c\xe6\x8a\xa51690.15\xe7\x82\xb9\"}" 127.0.0.1:6379>
加入 --raw 参数后可以显示可以阅读的数据
[hadoop@VM_3_2_centos ~]$ redis-cli --raw 127.0.0.1:6379> ZREVRANGE FASTNEWS_DATA_STORE_KEY 0 1 {"title":"上证综指周线五连阳,创业板连续两周大跌"} {"title":"上证综指周五收盘下跌0.21%,报3237.98点"} 127.0.0.1:6379>
1.3.2. --latency Enter a special mode continuously sampling latency.
参数的功能是从客户端发出一条命令到客户端接受到该命令的反馈所用的最长响应时间
# redis-cli --latency -h 192.168.2.1 min: 1, max: 210, avg: 3.64 (13453 samples)
1.3.3. auth
认证密码
[root@netkiller ~]# redis-cli 127.0.0.1:6379> keys * (error) NOAUTH Authentication required. 127.0.0.1:6379> auth hsM8NKb71vjbWJrA1TYgI4 OK 127.0.0.1:6379> keys *1) "HK50(1605)"2) "GBPUSD"3) "USDCHF"4) "SP500(1609)"5) "NZDJPY"6) "AUDNZD"7) "EURGBP"8) "CLN6"9) "BU6"
1.3.4. MONITOR
$ redis-cli monitor
1.3.5. info
redis 127.0.0.1:6379> info redis_version:2.4.10 redis_git_sha1:00000000 redis_git_dirty:0 arch_bits:64 multiplexing_api:epoll gcc_version:4.4.6 process_id:29663 uptime_in_seconds:1189 uptime_in_days:0 lru_clock:1018411 used_cpu_sys:0.10 used_cpu_user:0.09 used_cpu_sys_children:0.01 used_cpu_user_children:0.00 connected_clients:1 connected_slaves:0 client_longest_output_list:0 client_biggest_input_buf:0 blocked_clients:0 used_memory:730664 used_memory_human:713.54K used_memory_rss:7225344 used_memory_peak:730720 used_memory_peak_human:713.59K mem_fragmentation_ratio:9.89 mem_allocator:jemalloc-2.2.5 loading:0 aof_enabled:0 changes_since_last_save:0 bgsave_in_progress:0 last_save_time:1373332622 bgrewriteaof_in_progress:0 total_connections_received:4 total_commands_processed:14 expired_keys:0 evicted_keys:0 keyspace_hits:3 keyspace_misses:0 pubsub_channels:0 pubsub_patterns:0 latest_fork_usec:744 vm_enabled:0 role:master db0:keys=4,expires=0 redis 127.0.0.1:6379>
1.3.6. save/bgsave/lastsave
save/bgsave 保存持久化将数据,lastsave 查看相关信息
redis 127.0.0.1:6379> save OK redis 127.0.0.1:6379> bgsave Background saving started redis 127.0.0.1:6379> lastsave (integer) 1373335757
1.3.7. config
CONFIG GET dir CONFIG GET dbfilenameconfig set stop-writes-on-bgsave-error yes CONFIG SET dir /tmp CONFIG SET dbfilename temp.rdb
1.3.8. keys
查询所有key
172.18.52.15:6379> keys *1) "www.example.com:743f10d0f1dc569ed5893856e14c1fb7captcha"2) "www.example.com:d88e0b6c54a235763dd731bcc0914439captcha"3) "www.example.com:17f9091cb44f3cc5bb411eb801f07be8member_login"4) "www.example.com:10ff594fd42f4c81212020555cfb586amember_login_input"5) "www.example.com:a759ba5232ce324d0e6ae8da9290beaecaptcha"6) "www.example.com:37c78410af02d66a542d15b9707f215bcaptcha"7) "www.example.com:9f5070e217f4eac9a1d15f9b8dbe7148deposit_1_temp_var"8) "www.example.com:6c1a13c9396df2c35613043923bfe338captcha"9) "www.example.com:b611080c0627154871ea0e1498793238captcha" 10) "www.example.com:2792241f8d0f075528db2b50e0c9c684member_login"
查询指定key
172.18.50.15:6379> set name neo OK 172.18.50.15:6379> keys name 1) "name"
1.3.9. 字符串操作
1.3.9.1. set/get/del
172.18.52.15:6379> set name neo OK 172.18.52.15:6379> get name "neo" 172.18.52.15:6379> keys name 1) "name" 172.18.52.15:6379> del name (integer) 1 172.18.52.15:6379> get name (nil)
1.3.9.2. setnx
SETNX key value
当 key 不存在时将 key 的值设为 value,若给定的 key 已经存在,则 SETNX 不做任何动作。SETNX 是(SET if Not eXists) (如果不存在,则 SET)的简写。
返回值:设置成功,返回 1设置失败,返回 0redis> EXISTS neo # neo 不存在 (integer) 0redis> SETNX neo "chen" # neo 设置成功 (integer) 1redis> SETNX neo "netkiller" # 尝试覆盖 neo ,失败 (integer) 0redis> GET neo # 没有被覆盖 "chen"
1.3.10. expire/ttl
EXPIRE 设置过期时间, TTL 可以查询过期时间倒计时。
172.18.52.165:6379> set name neo OK 172.18.52.165:6379> ttl name (integer) -1 172.18.52.165:6379> expire name 30 (integer) 1 172.18.52.165:6379> ttl name (integer) 22 172.18.52.165:6379> ttl name (integer) 9 172.18.52.165:6379> ttl name (integer) -1 172.18.52.165:6379> get name (nil)
注意ttl返回-1有两种情况,一是没有设置过期时间,另一种是该key已经过期不存在。
1.3.11. 获取 key 类型
root@netkiller ~ % redis-cli 127.0.0.1:6379> TYPE "logstash:redis" list
1.3.12. LIST 数据类型
获取 list 列表长度
127.0.0.1:6379> TYPE "logstash:redis" list 127.0.0.1:6379> LLEN "logstash:redis" (integer) 69 127.0.0.1:6379> lpop "logstash:redis" 127.0.0.1:6379> 127.0.0.1:6379> LLEN "logstash:redis" (integer) 68
1. LPUSH/LPUSHX/LRANGE: /> redis-cli #在Shell提示符下启动redis客户端工具。 redis 127.0.0.1:6379> del queue:test (integer) 1 #queue:test键并不存在,该命令会创建该键及与其关联的List,之后在将参数中的values从左到右依次插入。 redis 127.0.0.1:6379> lpush queue:test a b c d (integer) 4 #取从位置0开始到位置2结束的3个元素。 redis 127.0.0.1:6379> lrange queue:test 0 2 1) "d" 2) "c" 3) "b" #取链表中的全部元素,其中0表示第一个元素,-1表示最后一个元素。 redis 127.0.0.1:6379> lrange queue:test 0 -1 1) "d" 2) "c" 3) "b" 4) "a" #queue:test2键此时并不存在,因此该命令将不会进行任何操作,其返回值为0。 redis 127.0.0.1:6379> lpushx queue:test2 e (integer) 0 #可以看到queue:test2没有关联任何List Value。 redis 127.0.0.1:6379> lrange queue:test2 0 -1 (empty list or set) #queue:test键此时已经存在,所以该命令插入成功,并返回链表中当前元素的数量。 redis 127.0.0.1:6379> lpushx queue:test e (integer) 5 #获取该键的List Value的头部元素。 redis 127.0.0.1:6379> lrange queue:test 0 0 1) "e"2. LPOP/LLEN: redis 127.0.0.1:6379> lpush queue:test a b c d (integer) 4 redis 127.0.0.1:6379> lpop queue:test "d" redis 127.0.0.1:6379> lpop queue:test "c" #在执行lpop命令两次后,链表头部的两个元素已经被弹出,此时链表中元素的数量是2 redis 127.0.0.1:6379> llen queue:test (integer) 23. LREM/LSET/LINDEX/LTRIM: #为后面的示例准备测试数据。 redis 127.0.0.1:6379> lpush queue:test a b c d a c (integer) 6 #从头部(left)向尾部(right)变量链表,删除2个值等于a的元素,返回值为实际删除的数量。 redis 127.0.0.1:6379> lrem queue:test 2 a (integer) 2 #看出删除后链表中的全部元素。 redis 127.0.0.1:6379> lrange queue:test 0 -1 1) "c" 2) "d" 3) "c" 4) "b" #获取索引值为1(头部的第二个元素)的元素值。 redis 127.0.0.1:6379> lindex queue:test 1 "d" #将索引值为1(头部的第二个元素)的元素值设置为新值e。 redis 127.0.0.1:6379> lset queue:test 1 e OK #查看是否设置成功。 redis 127.0.0.1:6379> lindex queue:test 1 "e" #索引值6超过了链表中元素的数量,该命令返回nil。 redis 127.0.0.1:6379> lindex queue:test 6 (nil) #设置的索引值6超过了链表中元素的数量,设置失败,该命令返回错误信息。 redis 127.0.0.1:6379> lset queue:test 6 hh (error) ERR index out of range #仅保留索引值0到2之间的3个元素,注意第0个和第2个元素均被保留。 redis 127.0.0.1:6379> ltrim queue:test 0 2 OK #查看trim后的结果。 redis 127.0.0.1:6379> lrange queue:test 0 -1 1) "c" 2) "e" 3) "c"4. LINSERT: #删除该键便于后面的测试。 redis 127.0.0.1:6379> del queue:test (integer) 1 #为后面的示例准备测试数据。 redis 127.0.0.1:6379> lpush queue:test a b c d e (integer) 5 #在a的前面插入新元素a1。 redis 127.0.0.1:6379> linsert queue:test before a a1 (integer) 6 #查看是否插入成功,从结果看已经插入。注意lindex的index值是0-based。 redis 127.0.0.1:6379> lindex queue:test 0 "e" #在e的后面插入新元素e2,从返回结果看已经插入成功。 redis 127.0.0.1:6379> linsert queue:test after e e2 (integer) 7 #再次查看是否插入成功。 redis 127.0.0.1:6379> lindex queue:test 1 "e2" #在不存在的元素之前或之后插入新元素,该命令操作失败,并返回-1。 redis 127.0.0.1:6379> linsert queue:test after k a (integer) -1 #为不存在的Key插入新元素,该命令操作失败,返回0。 redis 127.0.0.1:6379> linsert queue:test1 after a a2 (integer) 05. RPUSH/RPUSHX/RPOP/RPOPLPUSH: #删除该键,以便于后面的测试。 redis 127.0.0.1:6379> del queue:test (integer) 1 #从链表的尾部插入参数中给出的values,插入顺序是从左到右依次插入。 redis 127.0.0.1:6379> rpush queue:test a b c d (integer) 4 #通过lrange的可以获悉rpush在插入多值时的插入顺序。 redis 127.0.0.1:6379> lrange queue:test 0 -1 1) "a" 2) "b" 3) "c" 4) "d" #该键已经存在并且包含4个元素,rpushx命令将执行成功,并将元素e插入到链表的尾部。 redis 127.0.0.1:6379> rpushx queue:test e (integer) 5 #通过lindex命令可以看出之前的rpushx命令确实执行成功,因为索引值为4的元素已经是新元素了。 redis 127.0.0.1:6379> lindex queue:test 4 "e" #由于queue:test2键并不存在,因此该命令不会插入数据,其返回值为0。 redis 127.0.0.1:6379> rpushx queue:test2 e (integer) 0 #在执行rpoplpush命令前,先看一下queue:test中链表的元素有哪些,注意他们的位置关系。 redis 127.0.0.1:6379> lrange queue:test 0 -1 1) "a" 2) "b" 3) "c" 4) "d" 5) "e" #将queue:test的尾部元素e弹出,同时再插入到queue:test2的头部(原子性的完成这两步操作)。 redis 127.0.0.1:6379> rpoplpush queue:test queue:test2 "e" #通过lrange命令查看queue:test在弹出尾部元素后的结果。 redis 127.0.0.1:6379> lrange queue:test 0 -1 1) "a" 2) "b" 3) "c" 4) "d" #通过lrange命令查看queue:test2在插入元素后的结果。 redis 127.0.0.1:6379> lrange queue:test2 0 -1 1) "e" #将source和destination设为同一键,将queue:test中的尾部元素移到其头部。 redis 127.0.0.1:6379> rpoplpush queue:test queue:test "d" #查看移动结果。 redis 127.0.0.1:6379> lrange queue:test 0 -1 1) "d" 2) "a" 3) "b" 4) "c"
1.3.13. zset (有序集)
添加到集合
root@VM_3_2_centos /etc/nginx/conf.d % redis-cli -n 16 127.0.0.1:6379[16]> zadd book 1 "Linux" 1 127.0.0.1:6379[16]> zadd book 2 "Java" 1 127.0.0.1:6379[16]> zadd book 3 "Python" 1 127.0.0.1:6379[16]> zadd book 4 "PHP" 1 127.0.0.1:6379[16]>
zrange 查看集合内容
127.0.0.1:6379[16]> zrange book 0 -1 withscores 1) "Linux" 2) "1" 3) "Java" 4) "2" 5) "Perl" 6) "5"
指定开始和结束范围
127.0.0.1:6379[16]> zrange book 0 4 Linux Java Python PHP127.0.0.1:6379[16]> zrange book 1 4 Java Python PHP127.0.0.1:6379[16]> zrange book 2 3 Python PHP
zrem 删除集合成员
127.0.0.1:6379[16]> zadd book 5 "Rabby" 1 127.0.0.1:6379[16]> zrange book 4 5 Perl Rabby 127.0.0.1:6379[16]> zrem book Rabby 1 127.0.0.1:6379[16]> zrange book 4 5 Perl127.0.0.1:6379[16]> zrem book PHP Python 2
zcard 返回成员数量
127.0.0.1:6379[16]> zcard book 3
1.3.14. Pub/Sub 订阅与发布
redis 提供基本的MQ 功能,下面我们做一个演示
开启第一个终端窗口,订阅first second
$ redis-cli redis 127.0.0.1:6379> SUBSCRIBE first second Reading messages... (press Ctrl-C to quit) 1) "subscribe" 2) "first" 3) (integer) 1 1) "subscribe" 2) "second" 3) (integer) 2
开启第二个终端窗口,分别发送first second
$ redis-cli redis 127.0.0.1:6379> PUBLISH second Hello (integer) 1 redis 127.0.0.1:6379> PUBLISH first Helloworld!!! (integer) 1 redis 127.0.0.1:6379> quit
现在切换到第一个终端窗口,应该能够看到发送过来的字符串
$ redis-cli redis 127.0.0.1:6379> SUBSCRIBE first second Reading messages... (press Ctrl-C to quit) 1) "subscribe" 2) "first" 3) (integer) 1 1) "subscribe" 2) "second" 3) (integer) 21) "message" 2) "second" 3) "Hello"1) "message" 2) "first" 3) "Helloworld!!!"
1.3.15. flushdb 清空 Redis 数据
root@netkiller ~ % redis-cli 127.0.0.1:6379> flushdb OK 127.0.0.1:6379>
原文出处:Netkiller 系列 手札
本文作者:陈景峯
转载请与作者联系,同时请务必标明文章原始出处和作者信息及本声明。
1.3. redis-cli - Command-line client to redis-server相关推荐
- mysql客户端指令_mysql command line client(mysql命令行客户端)
mysql command line client(mysql命令行客户端) (2010-03-24 09:18:38) 标签: 文化 分类: 数据库 1.输入密码:****** 2.ues mysq ...
- mysql command line闪退_MySQL Command Line Client 打不开(闪退)的解决
网上搜索到的解决办法: 1.找到mysql安装目录下的bin目录路径. 2.打开cmd,进入到bin目录的路径下,输入mysql -u root -p. 问题分析: 1.查看mysql command ...
- MySQL中MySQL X.X Command Line Client一闪而过的问题
问题介绍:我安装完MySQL(我安装的是5.5)后,使用MySQL 5.5 Command Line Client,每次点击,总是一闪而过.解决方法如下: 首先进入cmd 切入MySQL的安装目录,然 ...
- mysql command line client和mysql.exe输入密码后闪退问题解决方法
本来今天刚有了新电脑,装上mysql使用时发现中文乱码的情况,于是按照我以前的方法设置了mysql的几个字符集,都设置成了utf8,但是还是不行,看网上说要设置my.ini中的默认字符集default ...
- MacOS svn:E230001 Can‘t use Subversion command line client: svn The path to the Subversion executabl
注意:本文仅针对于 MacOS 系统. 错误信息如下: Can't use Subversion command line client: svn The path to the Subversion ...
- mysql command line client闪一下消失
在启动MySQL后,通过软件可以操作数据库.在windows程序下找到MySQL-MySQL Server 5.6-mysql command line client,本来可以出现一个界面让用户输入密 ...
- mysql57数据库命令_MySQL 5.7 mysql command line client 使用命令详解
MySQL 5.7 MySQL command line client 使用命令 1.输入密码:****** 2.ues mysql;使用Mysql 3.show databases;显示数据库 4. ...
- mysql 5.6 command line client闪退_MySQL 5.6 Command Line Client 点开闪退解决方法
先看下连接mysql本地库的2种方式. 第一种运行cmd,键入mysql -uroot -p,如果提示'mysql'不是内部或外部命令,也不是可运行的程序或批处理文件.就将mysql的安装路径添加的系 ...
- Can't use Subversion command line client:svn
在Intellij IDEA里checkout东西时出先这个错误提示: Can't use Subversion command line client:svn Subversion command ...
- Mysql安装后打开MySQL Command Line Client闪退处理办法,亲测有效
1.找到此电脑,鼠标右击,点击管理 2.点击服务和应用程序->服务->找到MySQL鼠标右击启动 3.重新打开MySQL Command Line Client成功进入MySQL
最新文章
- Java 异常处理的 9 个最佳实践
- 浏览器设置是否显示图片,可随时切换
- 束文圣和黄立南Nature综述极端环境中的微生物多样性
- 杭电oj2035c语言答案,杭电oj 2035
- 利用windows的rar工具创建自解压安装文件的方法
- php 安装 phpunit,phpunit的安装
- How Tomcat Works(二十)
- win10一按右键就闪屏_升级Win10正式版后屏幕一直闪烁正确的解决办法
- 可变长参数以及面试题
- 《How to Use the TimeDistributed Layer for Long Short-Term Memory Networks in Python》学习笔记
- 【YY手机】用AVR单片机制作手机系列教程-基础篇
- 【Proteus仿真】51单片机+红外测距仪(GP2D12)+ADC0809模数转换
- 火箭十八连胜内幕大曝光(坚持看完)(搞笑)
- 计算机中的文件及文件命名规则,文件名的命名规则是什么
- CC2640R2F BLE5.0 CC2640R2F SPI驱动实现
- BLM模型:解决问题的前提是定义问题
- WireGuard组建大内网
- c语言判断字符是否为某字母,判断字符是否为字母
- 满足5G无线基础设施的故障安全要求
- 物联网+Android(SeekBar)、RGB灯控制