Redis常见命令和使用示例

目录

1.使用官方文档学习redis

2.核心命令

SET

GET

3.全局/通用命令

KEYS

EXISTS

DEL

EXPIRE

TTL

TYPE


1.使用官方文档学习redis

redis官网

Redis常见命令和使用示例_第1张图片

 点击搜索,输入,比如输入ping,会显示Commands,是一个命令,点击ping,跳转到用法页面

有详细的解释

Redis常见命令和使用示例_第2张图片

 左侧有非常多的命令可供学习,也有中文文档

Redis常见命令和使用示例_第3张图片

2.核心命令

注意:redis的命令不区分大小写  

先进入redis-cli,才能输入redis命令

[root@localhost redis]# redis-cli
127.0.0.1:6379> 
127.0.0.1:6379> 
127.0.0.1:6379> 
127.0.0.1:6379> 

此时进入了redis-cli

get/set  这是redis最核心的两个命令。

SET

功能:存储K-V 。set可以填写两个参数(key-value),参数类型必须是字符串

127.0.0.1:6379> set 提示:key value [expiration EX seconds|PX milliseconds] [NX|XX]

127.0.0.1:6379> set key1 value1
OK
127.0.0.1:6379> 

对于上述key-value,不需要加“”就是表示字符串的类型,给他们加上双引号或单引号都可以

[root@localhost redis]# redis-cli
127.0.0.1:6379> set key2 value2
OK
127.0.0.1:6379> set "key3" "value3"
OK

GET

功能:根据K获取V。get 后跟key,就可以得到value,并且是带双引号,是字符串类型的。如果不存在key,就会返回nil,和null一个意思

127.0.0.1:6379> get key1
"value1"
127.0.0.1:6379> get key3
"value3"
127.0.0.1:6379> get key100
(nil)

3.全局/通用命令

redis支持很多数据结构,整体上来说是键值对结构,k固定是字符串,v可以有多种类型,最常见的:字符串,哈希表,列表,集合,有序集合。都是value上的变化

操作不同的数据结构,都会有不同的命令

还有一些命令,在这些数据结构上都能使用,称作全局命令

KEYS

功能:用来查询当前服务器上匹配的key,通过一些特殊符号(通配符),用来描述key的模样,匹配上述摸样的key就能被查询出来

命令语法: :KEYS pattern(样式、模式,描述字符串的模样)

示例:

*:匹配任意字符序列(包括空字符序列)。KEYS * 匹配所有的键。

127.0.0.1:6379> KEYS *
1) "key3"
2) "key1"
3) "key2"
127.0.0.1:6379> 

?:匹配单个字符。KEYS key? 匹配以 "key" 开头,并且后面跟着一个字符的键,如 "key1"、"keyA"。

127.0.0.1:6379> KEYS key?
1) "key3"
2) "key1"
3) "key2"

[character]:匹配在括号内的任一字符。KEYS key[123] 匹配以 "key" 开头,并且后面跟着 "1"、"2" 或 "3" 的键,如 "key1"、"key2"、"key3"。

127.0.0.1:6379> KEYS key[123]
1) "key3"
2) "key1"
3) "key2"

[range]:匹配在范围内的任一字符。KEYS key[1-5] 匹配以 "key" 开头,并且后面跟着小写字母的键,如 "key1"、"key2"、"key3"。

127.0.0.1:6379> KEYS key[1-5]
1) "key3"
2) "key1"
3) "key2"

[^characters]:匹配不在括号内的任一字符。KEYS key[^abc] 匹配以 "key" 开头,并且后面跟着一个非 "a"、"b" 或 "c" 的字符的键。

127.0.0.1:6379> KEYS key[^123]
(empty list or set)
127.0.0.1:6379> KEYS key[^abc]
1) "key3"
2) "key1"
3) "key2"

\*:匹配以指定前缀开头的键。KEYS prefix* 匹配以 "prefix" 开头的键,如 "prefix123"、"prefixabc"。

127.0.0.1:6379> KEYS key1
1) "key1"
127.0.0.1:6379> KEYS key*
1) "key3"
2) "key1"
3) "key2"

*\:匹配以指定后缀结尾的键。KEYS *suffix 匹配以 "suffix" 结尾的键,如 "abcsuffix"、"defsuffix"。

127.0.0.1:6379> KEYS *3
1) "key3"

注意事项:keys 的时间复杂度是O(N),需要遍历所有的键,然后匹配出符合要求的键。因此再生产环境(线上环境,用户可以访问到的)下一般禁止使用keys,尤其是keys*,keys*是匹配redis中以keys开头的所有键,由于生产环境中key非常多,redis是一个单线程的服务器,就会导致执行keys*时间非常长,那么redis服务器就被阻塞,无法为其它客户端提供服了!会给用户体验造成影响

redis的一个经典用途就是作为数据冷热分离的热点数据缓存,热点数据首先是去查redis的,如果redis被阻塞了,此时其它的查询redis操作就超时了,此时这些请求只能去查数据库了,大量的数据同时请求数据库的查询,可能会导致过载,数据库也无法正常提供服务了,整个系统基本就处于瘫痪状态。

EXISTS

功能:用于检查给定键是否存在于数据库中。接受一个或多个键作为参数,并返回存在的键的数量。时间复杂度:O(1)

命令语法: :EXISTS key [key ...]

示例: 

EXISTS  key1:检查单个键key1是否存在,存在返回1

127.0.0.1:6379> EXISTS key1
(integer) 1
127.0.0.1:6379> EXISTS key2
(integer) 1
127.0.0.1:6379> EXISTS key3
(integer) 1

EXTIST key1 key2 ley3:同时检查多个键是否存在.返回存在的键的数量

127.0.0.1:6379> EXISTS key1 key2 key3
(integer) 3

注意:redis是一个基于客户端-服务器,通过网络通信的中间件。因此上述分开查询key是否存在和同时检查多个键是否存在是有区别的

同时检查多个键是否存在:

Redis常见命令和使用示例_第4张图片

 单独检查多个键是否存在:

Redis常见命令和使用示例_第5张图片

可以看出,分开的写法,会产生更多轮次的请求响应,也即网络通信。和直接操作内存来说,网络通信成本比较高,效率比较低

所以redis支持一个命令能操作多个key,减少网络通信。还提供了其它的机制来提高网络通信的效率

DEL

功能:删除指定的key

和EXISTS命令相同,也可以支持操作多个key

时间复杂度:O(1). 返回删除key的个数

命令语法: DEL key [key......]   

示例: 

 删除key4,key5

127.0.0.1:6379> set key4 1
OK
127.0.0.1:6379> set key5 1
OK
127.0.0.1:6379> del key4 key5
(integer) 2

这里的删除,和mysql中的删库删表来说危险性比较低, 作为缓存,如果丢失少量的数据,问题不大,但是如果丢失大批的数据,musql就会过载,导致系统瘫痪。mysql不能丢失数据,丢失了数据就查不到了。

EXPIRE

功能:用于为键设置过期时间。接受两个参数:键和以为单位的过期时间

设置键的过期时间  过期时间到达后,该键将自动被删除。

key必须已经存在,设置成功返回1,失败返回0.  时间复杂度:O(1)

命令语法: EXPIRE  key  seconds   

127.0.0.1:6379> set key6 1
OK
127.0.0.1:6379> expire key6 5
(integer) 1
127.0.0.1:6379> get key5
(nil)

基于redis实现的分布式锁,为了避免 出现不能正确解锁的情况,加锁时通常会设置一个过期时间,自动解锁。

TTL

功能:检查键的过期时间 

返回名为"key"的键的剩余过期时间,以秒为单位。如果键不存在或者没有设置过期时间,则返回-1。如果键已经过期,则返回-2。时间复杂度:O(1)

命令语法: TTL key 

示例: 

127.0.0.1:6379> set key7 1
OK
127.0.0.1:6379> expire key7 15
(integer) 1
127.0.0.1:6379> ttl key7
(integer) 10
127.0.0.1:6379> ttl key7
(integer) 1
127.0.0.1:6379> ttl key7
(integer) -2
127.0.0.1:6379> ttl key1
(integer) -1

redis的过期策略是如何实现的?

不能直接整体便利key,效率非常低,redis整体策略是:定期删除和惰性删除
定期删除:每次抽取一部分进行验证过期时间。保证抽取检查过程足够快。为了避免一次性删除大量过期键导致服务器阻塞,Redis将每次执行的删除数量限制在一个较小的范围内。

惰性删除:当客户端尝试访问一个键时,Redis会检查该键是否已过期。如果键已过期,则会立即删除该键并返回空结果。

通过惰性过期和定期过期策略的结合,Redis可以高效地管理键的过期,并保持内存的合理使

TYPE

功能:用于获取指定键的数据类型

可能返回的结果:none  string  list  hash  set  zset  stream(redis作为消息队列的时候,使用这个各类型的value)  时间复杂度:O(1)

命令语法: TYPE key

示例: 

返回值为"string",表示键"mykey"的数据类型是字符串(String)。
127.0.0.1:6379> type mykey
string

返回值为"list",表示键"mylist"的数据类型是列表(List)。
127.0.0.1:6379> LPUSH mylist "value"
(integer) 1
127.0.0.1:6379> type mylist
list

返回值为"set",表示键"myset"的数据类型是集合(Set)。
127.0.0.1:6379> SADD myset "value"
(integer) 1
127.0.0.1:6379> type myset
set

返回值为"hash",表示键"myhash"的数据类型是哈希(Hash)。
127.0.0.1:6379> HSET myhash field "value"
(integer) 1
127.0.0.1:6379> type myhash
hash

返回值为"zset",表示键"myzset"的数据类型是有序集合(Sorted Set)。
127.0.0.1:6379> ZADD myzset 1 "value"
(integer) 1
127.0.0.1:6379> type myzset
zset

返回值为"nil",表示键"nonexistingkey"不存在。
127.0.0.1:6379> TYPE nonexistingkey
none

 

你可能感兴趣的:(redis,redis,数据库,缓存)