Redis有5种数据结构类型,分别是字符串(strings)、哈希(hash)、列表(list)、集合(set)、有序集合(sorted set)。其中strings类型是最简单的数据类型,它可以包含任何数据,如jpg图片或者序列化的对象,但是值不能超过512M。要管理这些数据的话需要使用redis客户端工具redis-cli连接到redis服务后执行对应的命令。
一、redis-cli客户端常用选项
在Linux中要管理Redis服务或者数据的话需要通过redis-cli这个客户端工具来进行操作,如果是Java或者Python等语言的话还有专门的客户端工具,在Redis官网可以看到推荐。
redis-cli选项众多,下面说几个常用的:
-a:如果redis配置了密码的话需要使用这个选项来指定密码
-h:指定redis的地址,域名或者ip都可以
-p:指定redis的端口
-n:指定需要连接的数据库编号
-r:指定命令执行的次数
redis-cli -r 3 ping #ping 三次
-i:和r结合使用,指定多次命令执行的时间间隔
--bigkeys:找到内存占用比较大的键值,这些键值可能就是瓶颈
--latency:检查redis服务的网络延迟
--latency-histrory:以15秒为间隔显示多条网络延迟信息
redis-cli --latency-histrory
--stat:实时获取redis重要统计信息,虽然统计信息没有info全面,但是能实时看到增量变化
--raw:将返回的数据格式化再输出,常用于显示包含中文的Key,当key包含了中文时,登陆redis时增加该选项就可以正确获取到中文,否则是二进制格式
二、redis服务端常用命令
在介绍各个命令之前需要知道的是Redis提供了一个命令别名的功能,可以把默认命名修改或禁用以增强安全性,如果发现命令无法执行,就要检查配置文件中是否有这个配置了,比如:
rename-command FLUSHALL ""
1、Redis服务信息命令
ping:查看服务是否正常连接,如果正常的话会返回一个pong的输出
select:选择指定编号的数据库。Redis提供了0-15号数据库,默认是0,但是不推荐使用多个数据库来区分业务,真有这种需求的话考虑多实例更好
select 1 #Redis默认有16个数据库,编号是0-15,这里选择了1号数据库
info:获取服务相关统计信息,如Redis版本的查看,占用的内存等,和keys命令一样可以通配符
client list:查看已连接的客户端
config get:根据匹配条件查看服务配置信息,支持通配符
config get timeout #查看配置文件中timeout相关信息 config get requ* #查看requ开头的配置项
config set:在线修改redis配置,结合config rewrite可以实现不重启服务而修改配置
config set maxmemory 1gb #在线修改内存大小,支持各种单位
config rewrite:将在线配置写入到配置文件,不用重启服务
#在线修改redis最大内存 127.0.0.1:6379> config get maxmemory 1) "maxmemory" 2) "24000000000" 127.0.0.1:6379> config set maxmemory 26000000000 OK 127.0.0.1:6379> config get maxmemory 1) "maxmemory" 2) "26000000000" 127.0.0.1:6379> config rewrite OK
flushdb:删除当前选中库中的所有key,数据量大的时候有阻塞风险
flushall:删除所有库中的所有key,数据量大的时候有阻塞风险
dbsize:返回当前库中key的数量
save:将redis数据持久化存储到rdb文件,由于是前台运行会产生阻塞
bgsave:开启子现成进行数据持久化,不会阻塞
shutdown:优雅关闭redis
redis-cli -a 123456 -h 127.0.0.1 shutdown
2、Redis 数据操作命令
set:设置某个key的值,区分大小写,可以非交互写入
set site www.linuxe.cn #设置一个key,名为“site”,值为www.linuxe.cn redis-cli -h 192.168.100.10 -p 6379 set name tom #非交互式设置或读取key
get:获取某个key的值
get site #获取之前设置的“site”的值
rename:修改key的名字
rename oldkey newkey
renamenx:修改key的名字,只不过新的key名必须是不存在的才可以,避免覆盖已有的key
append:给key尾部追加值
append site good #在site这个key的value后面加上good字段
type:查看某个key的类型,是string还是hash……
mset:批量设置多个key,虽然命令时间不会变化,但是可以节约网络时间
mset key1 tom key2 jerry key3 john
exists:查看某个key是否存在,存在返回1,否则为0
randomkey:返回一个随机的key
keys:列出符合匹配条件的key,可以使用通配符进行遍历,如keys *,但是需要注意如果key数量特别多的话这样会导致服务阻塞,建议在从节点执行或者使用scan命令
setnx: 给某个不存在的key设置一个值,如果该key已存在则返回0,避免覆盖之前设置好的key(nx=not exist)
setex:给某个key设置一个值,并且指定一个有效期
setex name 10 tanglu #10秒过期
getset:获取一个key的旧值,并赋予新值
getset name tom #如name旧值为jerry,那么会打印出来,并且重新设置为tom
ttl:查看某个key的有效期,-1代表不过期,-2代表键不存在,其他数字代表距离过期秒数
ttl name
expire:设置某个已存在的key的有效期,单位为秒。还可以使用expireat来指定过期时间戳,通过一些转换工具可以方便的获取到时间戳
expire name 100
persist:把某个key设置为永久有效
persist name
del:删除一个或多个key,返回的值是成功删除的个数,如果删除的键不存在返回0。删除Bigkey会有阻塞风险
del key1 key2
unlink:4.0以上版本所支持新的删除Key方法,不会有阻塞问题
move:移动key到指定数据库
move age 2 #移动age这个key到2号数据库
incr:对某个整数型的key进行自增,应用场景比如微博转发增加次数
decr:对某个key进行自减
incrby:对某个key进行指定数值的增加
decrby:对某个key进行指定数值的减少