缓存技术redis系列(二)——redis数据结构(内存模型)以及常用命令

Redis数据类型

与Memcached仅支持简单的key-value结构的数据记录不同,Redis支持的数据类型要丰富得多,常用的数据类型主要有五种:String、List、Hash、Set和Sorted Set

Redis数据类型内存结构分析

Redis内部使用一个redisObject对象来表示所有的key和value。redisObject主要的信息包括数据类型(type)、编码方式(encoding)、数据指针(ptr)、虚拟内存(vm)等。type代表一个value对象具体是何种数据类型,encoding是不同数据类型在redis内部式。

wps39D7.tmp

                            redisObject 对象示意图

 

下面分别介绍5种数据类型的用法。

String类型

字符串是Redis值的最基础的类型。Redis中使用的字符串是通过包装的,基于c语言字符数组实现的简单动态字符串(simple dynamic string, SDS)一个抽象数据结构。其源码定义如下:

 

public class HashSetextends AbstractSetimplements Set, Cloneable, java.io.Serializable{static final long serialVersionUID = -5024744406713321676L;private transient HashMap map;// Dummy value to associate with an Object in the backing Mapprivate static final Object PRESENT = new Object();/*** Constructs a new, empty set; the backing HashMap instance has* default initial capacity (16) and load factor (0.75).*/public HashSet() {map = new HashMap<>();}....../*** Returns an iterator over the elements in this set.  The elements* are returned in no particular order.** @return an Iterator over the elements in this set* @see ConcurrentModificationException*/public Iterator iterator() {return map.keySet().iterator();}

 

可见创建一个HashSet的时候实际上创建了一个HashMap;Set中的元素,只是存放在了底层HashMap的key上,底层HashMap的value列为空,遍历HashSet的时候从HashMap中取出keySet来遍历。

 

wps39FB.tmp 

                               Set底层结构示意图

应用场景

集合有取交集、并集、差集等操作,因此可以求共同好友、共同兴趣、分类标签等。

常用命令

(1)sadd——在key对应的set中添加一个元素。

(2)smembers——获取key对应的set的所有元素。

(3)spop——随机返回并删除key对应的set中的一个元素。

192.168.2.129:6379> sadd myset news1 news2 news3(integer) 3192.168.2.129:6379> smembers myset1) "news3"2) "news2"3) "news1"192.168.2.129:6379> spop myset"news3"192.168.2.129:6379>

 (4)sdiff——求给定key对应的set与第一个key对应的set的差集

192.168.2.129:6379> smembers myset1) "news3"2) "news2"3) "news1"192.168.2.129:6379> sadd myset2 news3 news4 news5(integer) 3192.168.2.129:6379> smembers myset21) "news4"2) "news3"3) "news5"192.168.2.129:6379> sdiff myset myset21) "news1"2) "news2"192.168.2.129:6379>

 (5)suion——求给定key对应的set并集

192.168.2.129:6379> sunion myset myset21) "news3"2) "news1"3) "news2"4) "news4"5) "news5"192.168.2.129:6379>

(6)sinter——求给定key对应的set交集

192.168.2.129:6379> sinter myset myset21) "news3"192.168.2.129:6379>

 (7)其他命令

 

命令

说明

srem

删除key对应的set中的一个元素

sdiffstore

求给定key对应的set与第一个key对应的set的差集,并存储到另一个key对应的set中

sinterstore

求给定key对应的set交集,并存储到另一个key对应的set中

suionstore

求给定key对应的set并集,并存储到另一个key对应的set中

somve

从第一个key对应的set中删除指定元素并添加到第二个key对应的set中

scard

返回key对应的set的元素个数

sismember

测试某个元素是否为key对应的set中的元素个数

srandmember

随机返回key对应的set中的一个元素,但不删除元素

SortSet

SortSet顾名思义,是一个排好序的Set,它在Set的基础上增加了一个顺序属性score,这个属性在添加修改元素时可以指定,每次指定后,SortSet会自动重新按新的值排序。

sorted set的内部使用HashMap和跳跃表(SkipList)来保证数据的存储和有序,HashMap里放的是成员到score的映射,而跳跃表里存放的是所有的成员,排序依据是HashMap里存的score。

应用场景

如按时间排序的时间轴。

常用命令

(1)zadd ——在key对应的zset中添加一个元素

(2)zrange——获取key对应的zset中指定范围的元素,-1表示获取所有元素

192.168.2.129:6379> zadd myzset 1 "one" 2 "two" 3 "three"(integer) 3192.168.2.129:6379> zrange myzset 0 -11) "one"2) "two"3) "three"192.168.2.129:6379> zrange myzset 0 -1 withscores1) "one"2) "1"3) "two"4) "2"5) "three"6) "3"192.168.2.129:6379>

 (3)zrem——删除key对应的zset中的一个元素

192.168.2.129:6379> zrem myzset one(integer) 1192.168.2.129:6379> zrange myzset 0 -1 withscores1) "two"2) "2"3) "three"4) "3"192.168.2.129:6379>

 (4)其它命令

 

命令

说明

zincrby

如果key对应的zset中已经存在元素member,则对member的score属性加指定的值

zrank

返回key对应的zset中指定member的排名。其中member按score值递增(从小到大);排名以0为底,也就是说,score值最小的成员排名为0

zrevrank

获得成员按score值递减(从大到小)排列的排名

zrevrange

返回有序集key中,指定区间内的成员。其中成员的位置按score值递减(从大到小)来排列

zrangebyscore

返回有序集key中,指定分数范围的元素列表

zcount

返回有序集key中,score值在min和max之间(默认包括score值等于min或max)的成员

zcard

返回key的有序集元素个数

回到顶部

Redis常用命令

键值常用命令

keys/exits/del/expire/ttl/move/persist/randomkey/rename/type

服务器常用命令

ping/echo/select/quit/dbsize/info/config get/flushdb/flushall

这些命令都很容易使用,就不举例说明了。到此,redis的数据类型以及常用命令已经介绍完毕,下一篇我们将学习redis的一些高级特性。

回到顶部

参考文档

http://www.redis.cn/documentation.html

http://blog.csdn.net/tonysz126/article/details/8280696/


该文章转自:https://www.cnblogs.com/hjwublog/p/5639990.html


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部