【我与Redis的相爱相杀】详细讲解Redis五大常用数据类型在Linux系统下命令行代码的使用

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 【我与Redis的相爱相杀】详细讲解Redis五大常用数据类型在Linux系统下命令行代码的使用

一、基础操作

常用命令

keys * 查看当前库所有的key

exists key 判断某个key是否存在

type key 查看key是什么类型

del key 删除指定的key数据

unlink key 根据value选择非阻塞删除(真正的删除会在后续异步操作)

expire key 10 10秒钟:为给定的key设置过期时间

ttl key 查看还有多少秒过期,-1表示永不过期,-2表示已过期

select 切换数据库

dbsize 查看当前数据库的key的数量

flushdb 清空当前库

flushall 通杀全部库

代码实现

127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> set k2 v2
OK
127.0.0.1:6379> keys *
1) "k2"
2) "k1"
127.0.0.1:6379> exists k1
(integer) 1
127.0.0.1:6379> type k1
string
127.0.0.1:6379> del k2
(integer) 1
127.0.0.1:6379> keys *
1) "k1"


可以看到,set 用于创建键值对,del、exists、type等命令行都可以正常操作


127.0.0.1:6379> set k2 v2
OK
127.0.0.1:6379> keys * 
1) "k2"
2) "k1"
127.0.0.1:6379> unlink k2
(integer) 1
127.0.0.1:6379> keys *
1) "k1"
127.0.0.1:6379> expire k1 5
(integer) 1
127.0.0.1:6379> ttl k1
(integer) -2
127.0.0.1:6379> keys *
(empty array)


unlink命令在查找时,会发现是删除了的,但真正的删除会在后续异步操作;expire命令是设置key的过期时间,ttl是查看是否过期;过期了,意味着键值对的删除


二、字符串(String)

简介

String是Redis最基本的类型,一个key对应一个value

String类型是二进制安全的。意味着Redis的string可以包含任何数据,比如jpg图片或者序列化的对象。

String类型是Redis最基本的数据类型,一个Redis中字符串value最多可以是512M


常用命令

set <key><value> 添加键值对

get <key> 查询对应键值对

append <key><value> 将给定的value追加到原值的末尾

strlen <key> 获得值的长度

setnx <key><value> 只有在 key 不存在时 ,设置 key 的值

incr <key>将 key 中储存的数字值增1,只能对数字值操作,如果为空,新增值为1

decr <key>将 key 中储存的数字值减1,只能对数字值操作,如果为空,新增值为-1

incrby / decrby <key><步长> 将 key 中储存的数字值增减。自定义步长。

mset <key1><value1><key2><value2> .....同时设置一个或多个 key-value

mget <key1><key2><key3> .....同时获取一个或多个 value 原子性,有一个失败都失败

msetnx <key1><value1><key2><value2> .....同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在

getrange <key><起始位置><结束位置>获得值的范围

setrange <key><起始位置><value>用 value 覆写key所储存的字符串值,从<起始位置>开始(索引从0开始)

setex <key><过期时间><value>设置键值的同时,设置过期时间,单位秒

getset <key><value>以新换旧,设置了新值同时获得旧值

代码实现

127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> set k2 v2
OK
127.0.0.1:6379> set k3 v3
OK
127.0.0.1:6379> get k1
"v1"
127.0.0.1:6379> append k1 "111"
(integer) 5
127.0.0.1:6379> get k1
"v1111"
127.0.0.1:6379> strlen k1
(integer) 5
127.0.0.1:6379> setnx k4 v4
(integer) 1


通过代码演示,可以了解到相应命令的用法


127.0.0.1:6379> set k1 1
OK
127.0.0.1:6379> incr k1
(integer) 2
127.0.0.1:6379> get k1
"2"
127.0.0.1:6379> decr k1
(integer) 1
127.0.0.1:6379> get k1
"1"
127.0.0.1:6379> incrby k1 4
(integer) 5
127.0.0.1:6379> get k1
"5"
127.0.0.1:6379> decrby k1 4
(integer) 1
127.0.0.1:6379> get k1
"1"



上面代码研究的是自增自减相关的命令行,用起来还是很简单,很容易理解的


127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3
OK
127.0.0.1:6379> mget k1 k2 k3
1) "v1"
2) "v2"
3) "v3"
127.0.0.1:6379> msetnx k4 v4 k5 v5
(integer) 1
127.0.0.1:6379> mget k4 k5
1) "v4"
2) "v5"
127.0.0.1:6379> getrange k1 0 2
"v1"
127.0.0.1:6379> setrange k1 0 v1111
(integer) 5
127.0.0.1:6379> get k1
"v1111"
127.0.0.1:6379> getset k1 v1
"v1111"
127.0.0.1:6379> get k1
"v1"
127.0.0.1:6379> setex k1 5 v111
OK
127.0.0.1:6379> get k1
"v111"



以上代码演示的是多个键值对的设置以及多个键值对的获取,也是很容易理解的


三、列表(List)

简介

Redis 列表是简单的字符串列表,按照插入顺序排序。可以添加一个元素到列表的头部(左边)或者尾部(右边)


常用命令

lpush/rpush <key><value1><value2><value3> .... 从左边/右边插入一个或多个值。

lpop/rpop <key>从左边/右边吐出一个值。值在键在,值光键亡。

rpoplpush <key1><key2>从<key1>列表右边吐出一个值,插到key2列表左边。

lrange <key><start><stop>按照索引下标获得元素(从左到右)

lrange mylist 0 -1 0左边第一个,-1右边第一个,(0-1表示获取所有)

lindex <key><index>按照索引下标获得元素(从左到右)

llen <key>获得列表长度

linsert <key> before <value><newvalue>在value的后面插入newvalue插入值

lrem <key><n><value>从左边删除n个value(从左到右)

lset<key><index><value>将列表key下标为index的值替换成value

代码实现

127.0.0.1:6379> lpush k1 v11 v12 v13
(integer) 3
127.0.0.1:6379> lrange k1 0 -1
1) "v13"
2) "v12"
3) "v11"
127.0.0.1:6379> lpop k1
"v13"
127.0.0.1:6379> lpop k1
"v12"
127.0.0.1:6379> lpop k1
"v11"
127.0.0.1:6379> lrange k1 0 -1
(empty array)
127.0.0.1:6379> lpush k2 v21 v22 v23
(integer) 3



其中lrange k1 0 -1表示的是查看所有的key下的数据


127.0.0.1:6379> lpush k1 v11 v12 v13
(integer) 3
127.0.0.1:6379> rpoplpush k1 k2
"v11"
127.0.0.1:6379> lrange k2 0 -1
1) "v11"
2) "v23"
3) "v22"
4) "v21"
127.0.0.1:6379> lindex k2 0
"v11"
127.0.0.1:6379> llen k2
(integer) 4


可以通过下标获取key下的值,也可以通过llen来获取key下的长度


127.0.0.1:6379> lindex k2 0
"v11"
127.0.0.1:6379> llen k2
(integer) 4
127.0.0.1:6379> linsert k2 before v11 v10
(integer) 5
127.0.0.1:6379> lrange k2 0 -1
1) "v10"
2) "v11"
3) "v23"
4) "v22"
5) "v21"
127.0.0.1:6379> lrem k2 3 v10
(integer) 1
127.0.0.1:6379> lrange k2 0 -1
1) "v11"
2) "v23"
3) "v22"
4) "v21"
127.0.0.1:6379> lset k2 0 v00
OK
127.0.0.1:6379> lrange k2 0 -1
1) "v00"
2) "v23"
3) "v22"
4) "v21"



可以在key下的某个值前后插入新的值,组成新的列表


四、集合(Set)

简介

Redis set对外提供的功能与list类似是一个列表的功能,特殊之处在于set是可以自动排重的,当需要存储一个列表数据,又不希望出现重复数据时,set是一个很好的选择,并且set提供了判断某个成员是否在一个set集合内的重要接口,这个也是list所不能提供的。


常用命令

sadd <key><value1><value2> ..... 将一个或多个 member 元素加入到集合 key 中,已经存在的 member 元素将被忽略

smembers <key> 取出该集合的所有值。

sismember <key><value> 判断集合key是否为含有该value值,有1,没有0

scard<key> 返回该集合的元素个数。

srem <key><value1><value2> .... 删除集合中的某个元素。

spop <key> 随机从该集合中吐出一个值。

srandmember <key><n> 随机从该集合中取出n个值。不会从集合中删除 。

smove <source><destination>value 把集合中一个值从一个集合移动到另一个集合

sinter <key1><key2> 返回两个集合的交集元素。

sunion <key1><key2> 返回两个集合的并集元素。

sdiff <key1><key2> 返回两个集合的差集元素(key1中的,不包含key2中的)

代码实现

127.0.0.1:6379> sadd k1 v11 v12 v13 v11
(integer) 3
127.0.0.1:6379> smembers k1
1) "v12"
2) "v13"
3) "v11"
127.0.0.1:6379> sismember k1 v12
(integer) 1
127.0.0.1:6379> scard k1
(integer) 3
127.0.0.1:6379> srem k1 v12 v11
(integer) 2
127.0.0.1:6379> smembers k1
1) "v13"
127.0.0.1:6379> spop k1
"v13"
127.0.0.1:6379> smembers k1
(empty array)



这里的命令行其实跟列表List相差不多,不同的地方就是set集合中不能有重复值的出现


127.0.0.1:6379> sadd k1 v11 v22 v11 v33
(integer) 3
127.0.0.1:6379> sadd k2 v11 v44 v55
(integer) 3
127.0.0.1:6379> srandmember k1 2
1) "v11"
2) "v33"
127.0.0.1:6379> sinter k1 k2
1) "v11"
127.0.0.1:6379> sunion k1 k2
1) "v11"
2) "v44"
3) "v22"
4) "v33"
5) "v55"
127.0.0.1:6379> sdiff k1 k2 
1) "v22"
2) "v33"
127.0.0.1:6379> smove k1 k2 v22
(integer) 1
127.0.0.1:6379> smembers k2
1) "v11"
2) "v22"
3) "v44"
4) "v55"



主要涉及两个集合的操作:交集、并集和差集


五、哈希(Hash)

简介

Redis hash 是一个键值对集合

Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。

类似Java里面的Map<String,Object>


常用命令

hset <key><field><value>给集合中的 field键赋值value

hget <key1><field>从集合取出 value

hmset <key1><field1><value1><field2><value2>...批量设置hash的值

hexists<key1><field>查看哈希表 key 中,给定域 field 是否存在。

hkeys <key>列出该hash集合的所有field

hvals <key>列出该hash集合的所有value

hincrby <key><field><increment>为哈希表 key 中的域 field 的值加上增量 1 -1

hsetnx <key><field><value>将哈希表 key 中的域 field 的值设置为 value ,当且仅当域 field 不存在 .

代码实现

127.0.0.1:6379> hset user1 name tom
(integer) 1
127.0.0.1:6379> hget user1 name
"tom"
127.0.0.1:6379> hmset user1 password tom age 17
OK
127.0.0.1:6379> hexists user1 age
(integer) 1
127.0.0.1:6379> hkeys user1
1) "name"
2) "password"
3) "age"
127.0.0.1:6379> hvals user1
1) "tom"
2) "tom"
3) "17"
127.0.0.1:6379> hincrby user1 age 1
(integer) 18
127.0.0.1:6379> hset user1 password 12345
(integer) 0
127.0.0.1:6379> hset user1 phone 12345
(integer) 1
127.0.0.1:6379> hkeys user1
1) "name"
2) "password"
3) "age"
4) "phone"
127.0.0.1:6379> hvals user1
1) "tom"
2) "12345"
3) "18"
4) "12345"



从代码可以看到,hset user1 password 12345 会失败,需要注意一下


六、有序集合(Zset)

简介

Redis有序集合zset与普通集合set非常相似,是一个没有重复元素的字符串集合。

不同之处是有序集合的每个成员都关联了一个评分(score),这个评分(score)被用来按照从最低分到最高分的方式排序集合中的成员。集合的成员是唯一的,但是评分可以是重复的

因为元素是有序的, 所以你也可以很快的根据评分(score)或者次序(position)来获取一个范围的元素。

访问有序集合的中间元素也是非常快的,因此你能够使用有序集合作为一个没有重复成员的智能列表。


常用命令

zadd <key><score1><value1><score2><value2>… 将一个或多个 member 元素及其 score 值加入到有序集 key 当中

zrange <key><start><stop> [WITHSCORES] 返回有序集 key 中,下标在 之间的元素 ,带 WITHSCORES,可以让分数一起和值返回到结果集

zrangebyscore key minmax [withscores] [limit offset count] 返回有序集 key 中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员。有序集成员按 score 值递增(从小到大)次序排列

zrevrangebyscore key maxmin [withscores] [limit offset count] 同上,改为从大到小排列

zincrby <key><increment><value> 为元素的score加上增量

zrem <key><value> 删除该集合下,指定值的元素

zcount <key><min><max> 统计该集合,分数区间内的元素个数

zrank <key><value> 返回该值在集合中的排名,从0开始

代码实现

127.0.0.1:6379> zadd book 23 java 15 c 66 php 10 c++
(integer) 4
127.0.0.1:6379> zrange book 0 -1
1) "c++"
2) "c"
3) "java"
4) "php"
127.0.0.1:6379> zrangebyscore book 25 88
1) "php"
127.0.0.1:6379> zincrby book 2 java
"25"
127.0.0.1:6379> zrem book c++ 
(integer) 1
127.0.0.1:6379> zcount book 0 88
(integer) 3
127.0.0.1:6379> zrank book php
(integer) 2
127.0.0.1:6379> zrank book c
(integer) 0



有序集合的特点跟哈希差不多,区别是有序集合的每个成员都关联了一个评分,评分是可以重复的,集合的成员是唯一的


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
8天前
|
存储 缓存 NoSQL
解决Redis缓存数据类型丢失问题
解决Redis缓存数据类型丢失问题
135 85
|
11天前
|
存储 缓存 监控
Linux缓存管理:如何安全地清理系统缓存
在Linux系统中,内存管理至关重要。本文详细介绍了如何安全地清理系统缓存,特别是通过使用`/proc/sys/vm/drop_caches`接口。内容包括清理缓存的原因、步骤、注意事项和最佳实践,帮助你在必要时优化系统性能。
132 78
|
15天前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
52 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
4天前
|
NoSQL 关系型数据库 MySQL
Linux安装jdk、mysql、redis
Linux安装jdk、mysql、redis
72 7
|
11天前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
65 13
|
11天前
|
Ubuntu Linux C++
Win10系统上直接使用linux子系统教程(仅需五步!超简单,快速上手)
本文介绍了如何在Windows 10上安装并使用Linux子系统。首先,通过应用商店安装Windows Terminal和Linux系统(如Ubuntu)。接着,在控制面板中启用“适用于Linux的Windows子系统”并重启电脑。最后,在Windows Terminal中选择安装的Linux系统即可开始使用。文中还提供了注意事项和进一步配置的链接。
33 0
|
存储 NoSQL 测试技术
Redis介绍以及安装(Linux)
Redis介绍以及安装(Linux) redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统。和Memcached类似,但很大程度补偿了memcached的不足,它支持存储的value类型相对更多,包括string、list、set、zset和hash。
2325 0
|
2月前
|
消息中间件 缓存 NoSQL
Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。
【10月更文挑战第4天】Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。随着数据增长,有时需要将 Redis 数据导出以进行分析、备份或迁移。本文详细介绍几种导出方法:1)使用 Redis 命令与重定向;2)利用 Redis 的 RDB 和 AOF 持久化功能;3)借助第三方工具如 `redis-dump`。每种方法均附有示例代码,帮助你轻松完成数据导出任务。无论数据量大小,总有一款适合你。
84 6
|
5天前
|
缓存 监控 NoSQL
Redis经典问题:缓存穿透
本文详细探讨了分布式系统和缓存应用中的经典问题——缓存穿透。缓存穿透是指用户请求的数据在缓存和数据库中都不存在,导致大量请求直接落到数据库上,可能引发数据库崩溃或性能下降。文章介绍了几种有效的解决方案,包括接口层增加校验、缓存空值、使用布隆过滤器、优化数据库查询以及加强监控报警机制。通过这些方法,可以有效缓解缓存穿透对系统的影响,提升系统的稳定性和性能。