Redis的全称是REmote Dictionary Server,它主要提供了5种数据结构:字符串、哈希、列表、集合、有序集合,同时在字符串的基础之上演变 出了位图(Bitmaps)和HyperLogLog两种神奇的“数据结构”,并且随着 LBS(Location Based Service,基于位置服务)的不断发展,Redis3.2版本中 加入有关GEO(地理信息定位)的功能
现在先查看五种数据结构
字符串
字符串类型是Redis最基础的数据结构。首先键都是字符串类型,而且 其他几种数据结构都是在字符串类型基础上构建的,字符串类型的值实际可以是字符串(简单的字符串、复杂的字符串(例如JSON、XML))、数字(整数、浮点数),甚至是二进制(图片、音频、视频),但是值最大不能 超过512MB。
命令
set
set key value [ex seconds] [px milliseconds] [nx|xx]
实例
127.0.0.1:6379> keys *
(empty array)
127.0.0.1:6379> set name l
OK
127.0.0.1:6379> set age 20
OK
127.0.0.1:6379> set sex man
OK
分析
set命令有几个选项: ·ex seconds:为键设置秒级过期时间。 ·px milliseconds:为键设置毫秒级过期时间。 ·nx:键必须不存在,才可以设置成功,用于添加。 ·xx:与nx相反,键必须存在,才可以设置成功,用于更新。
除了set选项,Redis还提供了setex和setnx两个命令
setnx 是和set一样的 set xx是要求建存在才可以set
get
get key
127.0.0.1:6379> get name
"l"
127.0.0.1:6379> get age
"20"
127.0.0.1:6379> get sex
"man"
当get一个空值
127.0.0.1:6379> get null
(nil)
批量设置值,批量获取值
批量设置值
mset key value [key value ...]
批量获取值
mget key [key ...]
实例
127.0.0.1:6379> mset set1 1 set2 2 set3 3
OK
127.0.0.1:6379> mget set1 set2 set3
- "1"
- "2"
- "3"
注意:如果有些键不存在,那么它的值为nil(空)
ex:
127.0.0.1:6379> mget set1 set4 set2 set3
- "1"
- (nil)
- "2"
- "3"
学会使用批量操作,有助于提高业务处理效率,但是要注意的是每次批 量操作所发送的命令数不是无节制的,如果数量过多可能造成Redis阻塞或 者网络拥塞。
计数
incr key
incr命令用于对值做自增操作,返回结果分为三种情况:
·值不是整数,返回错误。
·值是整数,返回自增后的结果。
·键不存在,按照值为0自增,返回结果为1。
例如对一个不存在的键执行incr操作后,返回结果是1:
实例
127.0.0.1:6379> incr age
(integer) 21
127.0.0.1:6379> incr age
(integer) 22
除了incr命令,Redis提供了decr(自减)、incrby(自增指定数字)、 decrby(自减指定数字)、incrbyfloat(自增浮点数)
decr key
incrby key increment
decrby key decrement
incrbyfloat key increment
很多存储系统和编程语言内部使用CAS机制实现计数功能,有一定的 CPU开销,但在Redis中完全不存在这个问题,因为Redis是单线程架构,任何命令到了Redis服务端都要顺序执行。
更多命令
1.追加值 append
append key value
127.0.0.1:6379> get name
"l"
127.0.0.1:6379> APPEND name testappend
(integer) 11
127.0.0.1:6379> get name
"ltestappend"
2.字符串长度 strlen
strlen key
127.0.0.1:6379> STRLEN name
(integer) 11
3.设置并返回原值 getset
getset key value
getset和set一样会设置值,但是不同的是,它同时会返回键原来的值
127.0.0.1:6379> getset test ok
(nil)
127.0.0.1:6379> getset test change
"ok"
4.设置指定位置的字符 setrange
setrange key offeset value
127.0.0.1:6379> set setstrange best
OK
127.0.0.1:6379> get setstrange
"best"
127.0.0.1:6379> setrange setstrange 0 p
(integer) 4
127.0.0.1:6379> get setstrange
"pest"
5.获取部分字符串 getrange
getrange key start end
start和end分别是开始和结束的偏移量,偏移量从0开始计算
127.0.0.1:6379> set setgetrange hello
OK
127.0.0.1:6379> get setgetrange
"hello"
127.0.0.1:6379> getrange setgetrange 0 1
"he"
内部编码
字符串类型的内部编码有3种:
·int:8个字节的长整型。
·embstr:小于等于39个字节的字符串。
·raw:大于39个字节的字符串。
127.0.0.1:6379> set key1 2022
OK
127.0.0.1:6379> set key2 hello,world
OK
127.0.0.1:6379> set key3 this string is greater than 39 isisisisiisisisisisisiisisisisisis(error) ERR syntax error
127.0.0.1:6379> set key3 this string is greater than 39 isisisisiisi(error) ERR syntax error
127.0.0.1:6379> set key3 thisstringisgreaterthanlslslsllslslslsllslslslsllslsls
lsl
OK
127.0.0.1:6379> object encoding key1
"int"
127.0.0.1:6379> object encoding key2
"embstr"
127.0.0.1:6379> object encoding key3
"raw"
127.0.0.1:6379> STRLEN key3
(integer) 57
127.0.0.1:6379> STRLEN key2
(integer) 11
典型使用场景
1.缓存功能
Redis作为缓存层,MySQL作为存储层,绝大部分请求的数据都是从Redis中获取。由于Redis具有支撑高 并发的特性,所以缓存通常能起到加速读写和降低后端压力的作用。
2.计数
许多应用都会使用Redis作为计数的基础工具,它可以实现快速计数、 查询缓存的功能,同时数据可以异步落地到其他数据源
3.共享Session
等等