锋盈数科-知识库 Logo
首页
软件开发
计算机基础
Hello Halo
新手必读
关于本知识库
登录 →
锋盈数科-知识库 Logo
首页 软件开发 计算机基础 Hello Halo 新手必读 关于本知识库
登录
  1. 首页
  2. 软件开发
  3. Redis常见命令和使用示例

Redis常见命令和使用示例

0
  • 软件开发
  • 发布于 2024-09-19
  • 13 次阅读
黄健
黄健

目录

1.使用官方文档学习redis

2.核心命令

SET

GET

3.全局/通用命令

KEYS

EXISTS

DEL

EXPIRE

TTL

TYPE



1.使用官方文档学习redis

redis官网

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

有详细的解释

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

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"

\<prefix>*:匹配以指定前缀开头的键。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"

*\<suffix>:匹配以指定后缀结尾的键。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支持一个命令能操作多个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





原文链接: https://blog.csdn.net/chenchenchencl/article/details/131647189

标签: #redis 48 #软件开发 1171
相关文章

万字:支付“核心系统”详解 2024-11-02 15:33

专栏作者:隐墨星辰 \| 主编:陈天宇宙 这篇文章也尝试化繁为简,探寻支付系统的本质,讲清楚在线支付系统最核心的一些概念和设计理念。 虽然支付行业已经过了风头最劲的时光,但跨境支付仍然在蓬勃发展,每年依然有很多新人进入这个行业,这篇文章尝试为这些刚入行的新人提供一点帮助。 文章只介绍一些支付行业十几

资深支付架构师视角:实战从问题定义到代码落地的完整套路 2024-11-02 15:33

前言 今天从一个实际案例入手,介绍站在架构师的角度,如何识别并定义问题,提炼需求,技术方案选型,再到详细设计,最后利用AI的能力协助写出核心的代码,验证与调优。 解决问题存在一定的模式,也可以称之为框架,总结出自己的思考和解题框架,以后再碰到同类型的问题就可以如庖丁解牛一样容易。 很多年前,我写代码

Spring 实现 3 种异步接口 2024-10-18 09:07

大家好,我是苏三~ 如何处理比较耗时的接口? 这题我熟,直接上异步接口,使用 Callable、WebAsyncTask 和 DeferredResult、CompletableFuture等均可实现。 但这些方法有局限性,处理结果仅返回单个值。在某些场景下,如果需要接口异步处理的同时,还持续不断地

重学SpringBoot3-集成Redis(五)之布隆过滤器 2024-10-08 11:24

更多SpringBoot3内容请关注我的专栏:《SpringBoot3》 期待您的点赞👍收藏⭐评论✍ 重学SpringBoot3-集成Redis(五)之布隆过滤器 1. 什么是布隆过滤器? * 基本概念 适用场景 2. 使用 Redis 实现布隆过滤器 * 项目依赖 Redis 配置

设计模式第16讲——迭代器模式(Iterator) 2024-10-08 11:24

一、什么是迭代器模式 迭代器模式是一种行为型设计模式,它提供了一种统一的方式来访问集合对象中的元素,而不是暴露集合内部的表示方式。简单地说,就是将遍历集合的责任封装到一个单独的对象中,我们可以按照特定的方式访问集合中的元素。 二、角色组成 抽象迭代器(Iterator):定义了遍历聚合对象所需的方法

vue2路由和vue3路由区别及原理 2024-10-08 11:24

一、Vue2 与 Vue3 路由的区别 1. 创建路由实例方式的不同 Vue 2 中,通过 Vue.use() 注册路由插件,并通过 new VueRouter() 来创建路由实例。 import Vue from 'vue';import VueRouter from 'vue-router';i

目录

IT 外包服务商

  • 意见投递
  • zyf6619

软件开发应用

主菜单

  • 首页
  • 软件开发
  • 计算机基础
  • Hello Halo
  • 新手必读
  • 关于本知识库
Copyright © 2024 your company All Rights Reserved. Powered by Halo.