【入门篇】1.1 redis 基础数据类型详解和示例

文章目录

  • 1. 简介
  • 2. Redis基础数据类型
    • 2.1 String类型
      • 场景示例
      • 常用命令示例
    • 2.2 List类型
      • 场景示例
    • 2.3 Set类型
      • 场景示例
    • 2.4 Hash类型
      • 场景示例
    • 2.5 Sorted Set类型
  • 3. 使用Redis存储数据的注意事项
    • 1. 内存管理
    • 2. 数据持久化
    • 3. 高并发下的性能考量
  • 4. 参考资料

在这里插入图片描述

1. 简介

Redis概述

Redis 是一个开源的在内存中存储数据的结构化键值数据库,它支持多种类型的数据结构,如字符串、列表、集合、哈希、有序集合等。此外,Redis还支持事务、持久化、LUA脚本、LRU清除、自动故障转移等功能。

Redis特点

  • 性能高效:Redis能读的速度是110000次/s,写的速度是81000次/s,因此被广泛应用于缓存场景。

  • 支持多种数据类型:Redis支持最常见的数据类型,为复杂的应用提供了广泛的可能性。

  • 数据持久化:Redis可以将数据保存在磁盘上,重启后可以再次加载进行使用。

  • 支持消息队列:Redis还可以用作消息队列使用,它提供了发布/订阅等相关功能。

  • 支持事务:Redis支持事务,可以一次执行多个命令,中间不会被其他命令插入。

  • 高可用和分布式:通过Redis的Sentinel系统和Cluster集群模式,可以构建高可用、分布式的Redis系统。

Redis安装和启动

Redis的安装过程根据操作系统的不同而不同。以Linux为例,可以通过如下命令进行安装:

$ wget http://download.redis.io/releases/redis-5.0.3.tar.gz
$ tar xzf redis-5.0.3.tar.gz
$ cd redis-5.0.3
$ make

安装完成后,可以通过以下命令启动Redis:

$ src/redis-server

这样就成功启动了Redis服务器。要连接到这个服务器,可以打开另一个终端窗口,然后输入:

$ src/redis-cli

这样就可以开始使用Redis了。

2. Redis基础数据类型

2.1 String类型

String类型是Redis最基础的数据类型,是二进制安全的。它可以包含任何数据,例如jpeg图片或者序列化的对象,或者就简单的文本数据。String类型的value最大能存储512MB的数据。

场景示例

在一个电商平台中,用户的购物车信息可以使用String类型存储,例如存储用户ID和购物车商品数量的键值对。

SET user:1:cart 5
GET user:1:cart

常用命令示例

1. SET:

SET命令用于设置指定键的值,如果键已经存在则覆盖旧的值。

SET name "John Doe"

执行结果:OK。命令执行成功,则返回OK

2. GET:

GET命令用于获取指定键的值。

GET name

执行结果:"John Doe"。如果键存在则返回其对应的值,否则返回nil

3. INCR:

INCR命令用于将指定键的值增加1。如果键不存在,那么在操作前会先将其设置为0,然后再执行加1操作。

SET counter 100
INCR counter

执行结果:101INCR命令返回执行操作后的值。

4. DECR:

DECR命令用于将指定键的值减少1。同样,如果键不存在,那么在操作前会先将其设置为0,然后再执行减1操作。

DECR counter

执行结果:100DECR命令返回执行操作后的值。

2.2 List类型

List类型是Redis的一种复杂的数据类型,也是Redis的重要特性之一。Redis的List类型实际上是一个双向链表,所以添加一个新的元素到List的头部或者尾部的复杂度是O(1)。同时由于采用链表实现,你可以利用索引下标来获取元素,或者进行范围查询,这个操作的复杂度是O(N)。

场景示例

在一个即时通讯应用中,可以使用List类型存储聊天记录,每次发送的消息都会添加到List中。
命令示例:

LPUSH chat:room1 "Hello"
LPUSH chat:room1 "How are you?"
LRANGE chat:room1 0 -1

常用命令示例及执行结果

1. LPUSH:

LPUSH命令用于将一个或多个值插入到列表头部:

LPUSH mylist "World"
LPUSH mylist "Hello"

执行结果:2LPUSH命令返回此时列表的长度。

执行LRANGE mylist 0 -1命令查看列表,结果为:1) "Hello" 2) "World"

2. RPUSH:

RPUSH命令用于将一个或多个值插入到列表的尾部:

RPUSH mylist "Redis"

执行结果:3RPUSH命令返回此时列表的长度。

执行LRANGE mylist 0 -1命令查看列表,结果为:1) "Hello" 2) "World" 3) "Redis"

3. LPOP:

LPOP命令用于移除并返回列表的第一个元素:

LPOP mylist

执行结果:"Hello"LPOP命令返回被移除的元素的值。

执行LRANGE mylist 0 -1命令查看列表,结果为:1) "World" 2) "Redis"

4. RPOP:

RPOP命令用于移除并返回列表的最后一个元素:

RPOP mylist

执行结果:"Redis"RPOP命令返回被移除的元素的值。

执行LRANGE mylist 0 -1命令查看列表,结果为:1) "World"

以上即为Redis List类型的常用命令示例,以及它们的执行结果。对于更多的命令,你可以查阅Redis的官方文档进行学习。

2.3 Set类型

Set类型也是Redis的一种复杂数据类型,它是一种无序的、元素不重复的集合。由于集合中的元素是唯一的,所以可以使用Set类型来存储一些集合元素,并进行交集、并集、差集等操作。

场景示例

某个社交网络应用中,可以使用Set类型存储用户的好友列表,以便进行好友关系的管理。
命令示例:

SADD user:1:friends user:2
SADD user:1:friends user:3
SMEMBERS user:1:friends

常用命令示例

1. SADD:

SADD命令用于向集合添加一个或多个成员。

SADD myset "Hello"
SADD myset "World"

执行结果:1SADD命令返回添加成功的元素数量。

执行SMEMBERS myset命令查看集合,结果为:1) "Hello" 2) "World"

2. SREM:

SREM命令用于移除集合中一个或多个成员。

SREM myset "World"

执行结果:1SREM命令返回移除成功的元素数量。

执行SMEMBERS myset命令查看集合,结果为:1) "Hello"

3. SISMEMBER:

SISMEMBER命令用于判断成员元素是否是集合的成员。

SISMEMBER myset "World"
SISMEMBER myset "Hello"

执行结果:01SISMEMBER命令返回元素是否在集合中,0表示不在,1表示在。

2.4 Hash类型

Hash类型是Redis的一种复杂数据类型,它相当于一种简单的二级字典:第一级的key对应一个新的字典,这个新的字典就是Hash的内部结构,拥有自己的key-value对。Hash类型适合用于存储对象。

场景示例

某个网站需要存储用户的个人信息,可以使用Hash类型存储用户的姓名、年龄、性别等字段。
命令示例:

HSET user:1 name "John"
HSET user:1 age 25
HSET user:1 gender "Male"
HGETALL user:1

常用命令示例

1. HSET:

HSET命令用于为哈希表中的字段赋值。

HSET myhash field1 "Hello"
HSET myhash field2 "World"

执行结果:1HSET命令返回操作成功的数量。

执行HGETALL myhash命令查看哈希表,结果为:1) "field1" 2) "Hello" 3) "field2" 4) "World"

2. HGET:

HGET命令用于获取存储在哈希表中指定字段的值。

HGET myhash field1

执行结果:"Hello"HGET命令返回字段的值。

3. HGETALL:

HGETALL命令用于获取在哈希表中指定key的所有字段和值。

HGETALL myhash

执行结果:1) "field1" 2) "Hello" 3) "field2" 4) "World"HGETALL命令返回哈希表的所有字段和值。

2.5 Sorted Set类型

Sorted Set是Redis的一种复杂数据类型,也是集合的一种,能够存储一组数据,并且每个数据都有一个得分。数据是唯一的,但是得分(score)可以重复。集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。而得分的值是通过跳跃表来进行排序的。

场景示例:一个新闻网站可以使用Sorted Set类型存储热门新闻的排名,以便展示热门文章。
命令示例:

ZADD news:popular 1000 "Article1"
ZADD news:popular 800 "Article2"
ZADD news:popular 600 "Article3"
ZREVRANGE news:popular 0 -1 WITHSCORES

常用命令示例

1. ZADD:

ZADD命令用于向有序集合添加一个或多个成员,或者更新已存在成员的分数。

ZADD myzset 1 "one"
ZADD myzset 2 "two" 3 "three"

执行结果:1ZADD命令返回被成功添加的新成员的数量。

执行ZRANGE myzset 0 -1 WITHSCORES命令查看有序集合,结果为:1) "one" 2) "1" 3) "two" 4) "2" 5) "three" 6) "3"

2. ZSCORE:

ZSCORE命令返回有序集中,成员的分数值。

ZSCORE myzset "one"

执行结果:"1"ZSCORE命令返回成员的分数值。

3. ZRANGE:

ZRANGE命令用于返回有序集中,指定区间内的成员。

ZRANGE myzset 0 -1

执行结果:1) "one" 2) "two" 3) "three"ZRANGE命令返回指定区间内的成员。

3. 使用Redis存储数据的注意事项

1. 内存管理

  • Redis是基于内存的数据库,数据存储在内存中,因此需要注意合理使用内存。可以使用maxmemory参数限制Redis使用的最大内存大小,并使用相应的策略(如LRU)来处理内存不足的情况。
  • 对于大量数据存储的情况,可以考虑使用分片(sharding)或者集群(cluster)来扩展Redis的内存容量。

2. 数据持久化

  • Redis提供了两种持久化机制:RDB(Redis Database)和AOF(Append-Only File)。
  • RDB是将Redis在某个时间点的数据以快照的形式保存到硬盘上,适合用于备份和恢复数据。
  • AOF是将Redis的操作日志以追加的方式保存到硬盘上,适合用于持久化数据,但会增加IO的开销。
  • 可以根据实际需求选择合适的持久化机制,并配置相应的策略(如定时保存或根据操作数保存)来保证数据的安全性。

3. 高并发下的性能考量

  • Redis是单线程的,虽然性能非常高,但在高并发的情况下需要注意一些性能优化的问题。
  • 使用pipeline可以将多个命令打包发送,减少网络开销。
  • 使用批量操作命令(如MSET、MGET等)可以减少单个命令的调用次数,提高效率。
  • 合理使用连接池,避免频繁地建立和关闭连接。
  • 对于复杂的操作,可以考虑使用Lua脚本来减少网络通信开销。
  • 避免使用过多的阻塞操作,如BRPOP、BLPOP等,以免影响其他客户端的响应时间。

4. 参考资料

https://github.com/redis/redis

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/158765.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

app在线客服系统怎么对接

随着移动互联网的快速发展,越来越多的企业开始意识到在线客服系统的重要性。而对于一个App来说,一个高效的在线客服系统更是必不可少的。本文将介绍如何对接App在线客服系统,提高用户体验和客户满意度。 一、在线客服系统的作用和优势 1. 提供…

【Linux】:进程间通信

进程间通信 一.基本概念二.简单的通信-管道1.建立通信信道2.通信接口 一.基本概念 是什么 两个或多个进程实现数据层面的交互。 因为进程独立性的存在,导致进程间的通信成本比较高。 为什么 因为我们有多进程协同的需求。 怎么办 a.进程间通信的本质:必须让不…

TMS320F28335使用多个串口时,SCIRXST Register出现错误

TMS320F28335使用多个串口时,SCIRXST Register出现错误 void ClearErrorState(void) {if((SciaRegs.SCIRXST.bit.FE 1)||(SciaRegs.SCIRXST.bit.BRKDT 1)){SciaRegs.SCICTL1.bit.SWRESET 0;SciaRegs.SCICTL1.bit.SWRESET 1;}if((ScibRegs.SCIRXST.bit.FE 1)||(S…

反转链表(图解)

LCR 024. 反转链表 - 力扣(LeetCode) 题目描述 给定单链表的头节点 head ,请反转链表,并返回反转后的链表的头节点。 样例输入 示例 1: 输入:head [1,2,3,4,5] 输出:[5,4,3,2,1]示例 2&…

【漏洞复现】NUUO摄像头存在远程命令执行漏洞

漏洞描述 NUUO摄像头是中国台湾NUUO公司旗下的一款网络视频记录器,该设备存在远程命令执行漏洞,攻击者可利用该漏洞执行任意命令,进而获取服务器的权限。 免责声明 技术文章仅供参考,任何个人和组织使用网络应当遵守宪法法律&…

leetcode栈和队列三剑客

用队列实现栈 队列是先进先出的,而栈是只能在栈顶进行出栈和入栈,那我们这道题要用队列来实现栈的话,这里给的思路是两个队列,因为两个队列的话就可以相互导数据,比如我们来实现这个题目的push函数,我们的栈…

根据店铺ID/店铺链接/店铺昵称获取京东店铺所有商品数据接口|京东店铺所有商品数据接口|京东API接口

要获取京东店铺的所有商品数据,您需要使用京东开放平台提供的API接口。以下是一些可能有用的API接口: 商品SKU列表接口:该接口可以获取指定店铺下的所有商品SKU列表,包括商品ID、名称、价格等信息。您可以使用该接口来获取店铺中…

springMvc中的拦截器【巩固】

先实现下想要的拦截器功能 package com.hmdp.utils;import com.hmdp.entity.User; import org.springframework.web.servlet.HandlerInterceptor;import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.Ht…

python_主动调用其他类的成员

# 主动调用其他类的成员 # 方式一: class Base(object):def f1(self):print("5个功能") class Foo(object):def f1(self):print("3个功能")# Base.实例方法(自己传self),与继承无关Base.f1(self)obj Foo() obj.f1()print("#"*20)# 方式二:按照类…

jbase虚拟M层的设计

对于只是自己产品内部使用的打印程序来说(比如打印收费单,打印结算单等),打印逻辑写在js,获取其他层都是没毛病的。但是对于类型检验报告这种打印来说,打印格式控制逻辑写在js层是百分百不行的。因为检验报…

【proverif】proverif的语法-各种密码原语的介绍和具体编码

proverif-系列文章目录 【proverif】proverif的下载安装和初使用【proverif】proverif的语法-解决中间人攻击-代码详解【proverif】proverif的语法2-各种密码原语的编码 (本文) 文章目录 proverif-系列文章目录前言铺垫知识一、对称加密二、非对称加密三…

大模型幻觉成应用落地难题 最新评测文心一言解决幻觉能力最好

大模型中的幻觉问题 “林黛玉倒拔垂杨柳”、“月球上面有桂树”、“宋江字武松”……相信经常使用大语言模型都会遇到这样“一本正经胡说八道”的情况。这其实是大模型的“幻觉”问题,是大模型行业落地的核心挑战之一。例如幻觉会影响生成内容的可靠性,…

大数据基础设施搭建 - Hadoop

文章目录 一、下载安装包二、上传压缩包三、解压压缩包四、配置环境变量五、测试Hadoop5.1 测试hadoop命令5.2 测试wordcount案例5.2.1 创建wordcount输入文本信息5.2.2 执行程序5.2.3 查看结果 六、分发压缩包到集群中其他机器6.1 分发压缩包6.2 解压压缩包6.3 配置环境变量 七…

TDengine Restful Authorization 自定义Token

Restful 接口是 TDengine 最常用的接口,仅次于 JDBC。TDengine 支持 HTTP 和 HTTPS,但通常情况下,大家不想搞证书,又在内网环境中,采用 HTTP 方式比较多。但 HTTP 是明文传输,只要抓个包就知道账号密码了。…

2.4 矩阵的运算法则

矩阵是数字或 “元素” 的矩形阵列。当矩阵 A A A 有 m m m 行 n n n 列,则是一个 m n m\times n mn 的矩阵。如果矩阵的形状相同,则它们可以相加。矩阵也可以乘上任意常数 c c c。以下是 A B AB AB 和 2 A 2A 2A 的例子,它们都是 …

YOLOv5项目实战(4)— 简单三步,教你按比例划分数据集

前言:Hello大家好,我是小哥谈。本节课就教大家如何去按照比例去划分数据集,希望大家学习之后可以有所收获!~🌈 前期回顾: YOLOv5项目实战(1)— 如何去训练模型 YOLOv5项目

万字长文:从 C# 入门学会 RabbitMQ 消息队列编程

RabbitMQ 简介 RabbitMQ 是一个实现了 AMQP 协议的消息队列,AMQP 被定义为作为消息传递中间件的开放标准的应用层协议。它代表高级消息队列协议,具有消息定位、路由、队列、安全性和可靠性等特点。 目前社区上比较流行的消息队列有 kafka、ActiveMQ、Pul…

freeRTOS--软件定时器

一、什么是定时器: 简单可以理解为闹钟,到达指定一段时间后,就会响铃。STM32 芯片自带硬件定时器,精度较高、达到定时时间后会触发中断,也可以生成 PWM 、输入捕获、输出比较,等等,功能强大&am…

基于黄金正弦算法优化概率神经网络PNN的分类预测 - 附代码

基于黄金正弦算法优化概率神经网络PNN的分类预测 - 附代码 文章目录 基于黄金正弦算法优化概率神经网络PNN的分类预测 - 附代码1.PNN网络概述2.变压器故障诊街系统相关背景2.1 模型建立 3.基于黄金正弦优化的PNN网络5.测试结果6.参考文献7.Matlab代码 摘要:针对PNN神…

从0开始学习数据结构 C语言实现 1.前篇及二分查找算法

一、前篇 1、什么是数据结构? 数据结构是带有结构特性的数据元素的集合,它研究的是数据的逻辑结构和数据的物理结构以及它们之间的相互关系 2、时间复杂度与空间复杂度 大O符号是用于描述函数渐进行为的数学符号 常用函数的增长表 阶乘O(n!) > 指数…