Redis学习

一、Redis简介

Redis(REmote DIctionary Service),常被称为数据结构服务器,也是一个高性能的key-value数据库。

Redis与其他的key-value缓存产品有以下三个区别:

1、Redis支持数据的持久化,可以将内存中的数据保存到磁盘中,重启的时候可以再次加载到内存中使用。
2、Redis不仅仅支持key-value类型的数据,还提供了list、set、zset、hash等数据结构的存储。
3、Redis支持数据的备份,即master-slave模型的数据备份。
4、Redis是单线程的,通过多路复用提高处理效率。

Redis的优势:

1、性能极高,读速度能达到110000次/s,写速度达到81000次/s
2、丰富的数据类型
3、操作的原子性,要么成功执行,要么失败不执行
4、丰富的特性。Redis还支持publish/subscribe、通知、key过期等特性。

二、Redis基本命令

2.1 连接本地Redis服务器
$ redis-cli
127.0.0.1:6379> 
2.2 连接远程Redis服务器
$ redis-cli -h host -p port -a password
2.3 Redis key命令
命令 说明
DEL key 删除key
RENAME key newkey 重命名key为newkey
RENAMENX key newkey 仅当newkey不存在时,将key重命名为newkey
EXISTS key 检查key是否存在
TYPE key 返回key所存储的值的类型
EXPIRE key seconds 设置key的过期时间,单位为秒
PEXPIRE key milliseconds 设置key的过期时间,单位为毫秒
EXPIREAT key timestamp 设置key的过期时间,timestamp为Unix时间戳
KEYS pattern 查找所有符合给定模式pattern的key
MOVE key db 将当前数据库的key移到给定db
2.4 Redis字符串命令
命令 说明
SET key value 设置key的值
GET key 获取key的值
GETRANGE key start end 返回key中字符串值的子字符串
MGET key1 [key2...] 返回给定的一个或多个key的值
STRLEN key 返回key所存储的字符串值的长度
APPEND key value 如果key已经存在,则将value追加到该key原来的值后面
2.5 Redis hash命令
命令 说明
HMSET key field1 value1 [field2 value2...] 同时将多个field-value值设置到哈希表key中
HSET key field value 将哈希表key中的字段field的值设置为value
HMGET key field1 [field2...] 获取所给定(一个或多个)字段的值
HGET key field1 获取所给定字段的值
HGETALL key 获取哈希表key的所有字段和值
HKEYS key 获取哈希表key的所有字段
HVALS key 获取哈希表key中的所有值
HLEN key 获取哈希表key的字段数量
2.6 Redis list命令
命令 说明
LPUSH key value1 [value2...] 将一个或多个值插入到列表头部
LPUSHX key value 将一个值插入到已存在列表的头部
LPOP key 移除并返回列表的第一个元素
RPOP key 移除并返回列表的最后一个元素
LRANGE key start end 返回列表指定范围内的元素
LINDEX key index 通过索引获取列表中的元素
LLEN key 返回列表的长度
LREM key count value                                                                                                                                                                     移除列表中的元素。注:count>0表示从表头向表尾搜索,移除与value相等的元素,数量为count;count<0表示从表尾向表头搜索,移除与value相等的元素,数量为count的绝对值;count=0表示移除所有与value相等的元素
LSET key index value 通过索引设置列表元素的值
LTRIM key start end 对列表进行修剪,即只保留指定区间内的元素,不在指定区间内的删除
2.7 Redis set命令
命令 说明
SADD key member1 [member2...] 向集合添加一个或多个成员
SREM key member1 [member2...] 移除集合中一个或多个成员
SCARD key 获取集合的成员数
SMEMBERS key 返回集合中的所有成员
SDIFF key1 key2 返回key1与key2的差异
SINTER key1 [key2...] 返回给定集合间的交集
SUNION key1 [key2...] 返回给定集合的并集
SPOP key 移除并返回集合中随机的一个成员
2.8 Redis zset命令
命令 说明
ZADD key score1 member1 [score2 member2...] 向有序集合添加一个或多个成员,或者更新已存在的成员的分数
ZRANGE key start end [WITHSCORES] 通过索引区间返回指定区间内的成员
ZCARD key 返回有序集合的成员数
ZCOUNT key min max 统计有序集合指定区间分数内的成员数
ZLEXCOUNT key min max 统计有序集合指定字典区间内的成员数,与上一个不同的是,上一个是指定分数,这个是指定字典
ZRANGEBYLEX key min max 通过字典区间返回有序集合的成员
ZRANGEBYSCORE key min max 通过分数区间返回有序集合的成员
127.0.0.1:6379> zrange azset 0 10 withscores
 1) "a"
 2) "0"
 3) "b"
 4) "0"
 5) "c"
 6) "0"
 7) "d"
 8) "0"
 9) "f"
10) "0"
11) "g"
12) "0"
13) "h"
14) "0"
127.0.0.1:6379> zcount azset 0 10
(integer) 7
127.0.0.1:6379> zlexcount azset 0 10
(error) ERR min or max not valid string range item
127.0.0.1:6379> zlexcount azset [a [f
(integer) 5

三、Redis事务

Redis单个命令操作是原子性的,但是事务操作并不是原子性的,事务中的某个命令执行失败并不会回滚之前已执行的,也不会影响后续即将要执行的命令。
Redis以MULTI开始一个事务,然后将多个命令入队到事务中,最后以EXEC命令触发事务,一并执行队列中的所有命令。

127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> set book_name "Master Python in 21 days"
QUEUED
127.0.0.1:6379> get book_name
QUEUED
127.0.0.1:6379> sadd tag "Python" "Programming" "Mastering Series"
QUEUED
127.0.0.1:6379> smembers tag
QUEUED
127.0.0.1:6379> EXEC
1) OK
2) "Master Python in 21 days"
3) (integer) 3
4) 1) "Programming"
   2) "Python"
   3) "Mastering Series"
127.0.0.1:6379> 

四、Redis的应用场景

1、缓存。这是Redis最常用的场景。Redis是基于内存的数据存储器,有着优异的数据读写性能。
2、计数器。Redis提供的INCR命令来实现计数器的功能,内存操作,性能非常好。
3、分布式会话。在应用较多的复杂的集群系统中,一般会搭建以Redis等内存数据库为中心的session服务,来管理session。
4、分布式锁。Redis单线程的这个特性,非常适合用作分布式锁
5、排行榜。Redis提供的有序集合数据结构能实现各种复杂的排行榜功能。
6、社交网络。Redis提供的哈希、集合等数据结构能较好地处理诸如点赞、关注、被关注、共同好友等社交网络的需求。
7、最新列表。Redis的列表结构,LTRIM可以控制列表的长度。
8、消息系统。Redis提供了发布/订阅及阻塞队列功能,能实现一个简单的消息队列系统,不过这个不能和专业的消息队列中间件相比。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352

推荐阅读更多精彩内容