redis的基本使用

一、 Redis简介

  1. Redis是一个基于内存的 key-value 结构数据库。Redis是一款采用key-value数据存储格式的内存级NoSQL数据库,重点关注数据存储格式,是key-value格式,也就是键值对的存储形式。与MySQL数据库不同,MySQL数据库有表、有字段、有记录,Redis没有这些东西,就是一个名称对应一个值,并且数据以存储在内存中使用为主。什么叫以存储在内存中为主?其实Redis有它的数据持久化方案,分别是RDB和AOF,但是Redis自身并不是为了数据持久化而生的,主要是在内存中保存数据,加速数据访问的,所以说是一款内存级数据库。
  2. 官网介绍:Redis是一个开源(BSD许可),内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代理。它支持字符串、哈希表、列表、集合、有序集合,位图,hyperloglogs等数据类型。内置复制、Lua脚本、LRU收回、事务以及不同级别磁盘持久化功能,同时通过Redis Sentinel提供高可用,通过Redis Cluster提供自动分区
  3. 特点:
    • 基于内存存储,读写性能高
    • 适合存储热点数据(热点商品、资讯、新闻)
    • 企业应用广泛

Redis在windows下的安装

  1. Redis安装包分为 Windows 版和 Linux 版:

    • Windows版下载地址:https://github.com/microsoftarchive/redis/releases
    • Linux版下载地址: https://download.redis.io/releases/
      在这里插入图片描述
  2. 下载的安装包有两种形式,一种是一键安装的msi文件,还有一种是解压缩就能使用的zip文件,哪种形式都行。

    • 啥是msi,其实就是一个文件安装包,不仅安装软件,还帮你把安装软件时需要的功能关联在一起,打包操作。比如如安装序列、创建和设置安装路径、设置系统依赖项、默认设定安装选项和控制安装过程的属性。说简单点就是一站式服务,安装过程一条龙操作一气呵成,就是为小白用户提供的软件安装程序。
  3. Redis的Windows版属于绿色软件,直接解压zip文件即可使用,解压后目录结构如下:
    在这里插入图片描述

二、服务器启动命令

  1. 服务启动命令:redis-server.exe redis.windows.conf(要在该文件夹目录下进行)
    在这里插入图片描述
    通过快捷键Ctrl + C 即可停止Redis服务

三、客户端连接命令

  1. 客户端连接命令:redis-cli.exe
    在这里插入图片描述
  2. 注意:通过redis-cli.exe命令默认连接的是本地的redis服务,并且使用默认6379端口(初学者无需调整服务器对外服务端口,默认6379。)。也可以通过指定如下参数连接:
    • -h ip地址
    • -p 端口号
    • -a 密码(如果需要)

四、 5种常用数据类型

  1. Redis存储的是key-value结构的数据,其中key是字符串类型,value有5种常用的数据类型:
    • 字符串 string:普通字符串,Redis中最简单的数据类型(常用)
    • 哈希 hash:也叫散列,类似于Java中的HashMap结构(一般拿来存储对象)
    • 列表 list:按照插入顺序排序,可以有重复元素,类似于Java中的LinkedList(使用例子:朋友圈的点赞)
    • 集合 set:无序集合,没有重复元素,类似于Java中的HashSet(使用例子:
    • 有序集合 (sorted set / zset):集合中每个元素关联一个分数(score),根据分数升序排序,没有重复元素(使用例子:各种排行榜)

五. redis的常用命令

5.1. 字符串操作命令

  1. Redis 字符串类型常用命令:
    • (SET key value):设置指定key的值
    • (GET key):获取指定key的值
    • (SETEX key seconds value ):设置指定key的值,并将 key 的过期时间设为 seconds 秒(常用的例子:短信的验证码)
    • (SETNX key value):只有在 key 不存在时设置 key 的值(常用例子:分布式锁)

用法说明:

set name tom   =》表示 设置 键名为name的值为tom,这里的name就是key的名称(键名)get name    =》表示 获取 键名为name的值setex age 60 100  =》表示 设置 键名为age的值为100,并把age的过期时间设置为60秒。(从创建完成后开始计时60秒,之后该键名的值就会失效。setnx month 12     =》当month键名不存在时,表示设置month的值为12,当month键名已经存在时,命令失效,无法设置成功。

5.2. 哈希操作命令

  1. Redis hash 是一个string类型的 field 和 value 的映射表,hash特别适合用于存储对象,常用命令:
    • (HSET key field value): 将哈希表 key 中的字段 field 的值设为 value
    • (HGET key field): 获取存储在哈希表中指定字段的值
    • (HDEL key field):删除存储在哈希表中的指定字段
    • (HKEYS key): 获取哈希表中所有字段
    • (HVALS key):获取哈希表中所有值

用法说明:

hset 1 name zhangsan   
=》表示 设置 key为1的哈希表,key里面filed的值为name,filed对应的值为zhangsan(可以把filed看成属性,然后把value看成属性值)hget 1 name   
=》表示 获取 存储在key为1的哈希表里面的字段为name的值hdel 1 name 
=》表示删除存储在key为1的哈希表中里面的字段名为name的字段hkeys 1 
=》表示获取key为1的哈希表的所有字段hvals 1
=》表示获取key为1的哈希表里面的所有字段的值

在这里插入图片描述

5.3. 列表操作命令

  1. Redis 列表是简单的字符串列表,按照插入顺序排序,常用命令:
    • (LPUSH key value1 [value2] ): 将一个或多个值插入到列表头部(左边)
    • (LRANGE key start stop ): 获取列表指定范围内的元素
    • (RPOP key ): 移除并获取列表最后一个元素(右边)
    • (LLEN key ): 获取列表长度

在这里插入图片描述

5.4. 集合操作命令

  1. Redis set 是string类型的无序集合。集合成员是唯一的,集合中不能出现重复的数据,常用命令:
    • (SADD key member1 [member2] ): 向集合添加一个或多个成员
    • (SMEMBERS key ): 返回集合中的所有成员
    • (SCARD key ): 获取集合的成员数
    • (SINTER key1 [key2] ): 返回给定所有集合的交集
    • (SUNION key1 [key2] ): 返回所有给定集合的并集
    • (SREM key member1 [member2] ): 删除集合中一个或多个成员

5.5. 有序集合操作命令

  1. Redis有序集合是string类型元素的集合,且不允许有重复成员。每个元素都会关联一个double类型的分数。常用命令:
    • (ZADD key score1 member1 [score2 member2] ): 向有序集合添加一个或多个成员
    • (ZRANGE key start stop [WITHSCORES] ): 通过索引区间返回有序集合中指定区间内的成员
    • (ZINCRBY key increment member ): 有序集合中对指定成员的分数加上增量 increment
    • (ZREM key member [member …] ): 移除有序集合中的一个或多个成员

5.6. redis通用操作命令

  1. Redis的通用命令是不分数据类型的,都可以使用的命令:
    • (KEYS pattern ): 查找所有符合给定模式( pattern)的 key
    • (EXISTS key ): 检查给定 key 是否存在
    • (TYPE key ): 返回 key 所储存的值的类型
    • (DEL key ): 该命令用于在 key 存在是删除 key

六、在java中操作redis

6.1. redis的java客户端

  1. Redis 的 Java 客户端很多,常用的几种:

    • Jedis
    • Lettuce
    • Spring Data Redis
  2. Spring Data Redis 是 Spring 的一部分,对 Redis 底层开发包进行了高度封装。
    在 Spring 项目中,可以使用Spring Data Redis来简化操作。

6.1.1. Spring Data Redis 的使用方式

  1. 操作步骤:
      1. 导入Spring Data Redis 的maven坐标
      1. 配置Redis数据源
      1. 编写配置类,创建RedisTemplate对象,然后通过RedisTemplate对象操作Redis

步骤①:导入springboot整合redis的starter坐标
在这里插入图片描述
上述坐标可以在创建模块的时候通过勾选的形式进行选择,归属NoSQL分类中
在这里插入图片描述
步骤②:进行基础配置

spring:redis:host: localhostport: 6379database: 10   # database是指定使用redis里面的哪个数据库(默认用的是0数据库)

操作redis,最基本的信息就是操作哪一台redis服务器,所以服务器地址属于基础配置信息,不可缺少。但是即便你不配置,目前也是可以用的。因为以上两组信息都有默认配置,刚好就是上述配置值。

步骤③:使用springboot整合redis的专用客户端接口操作,此处使用的是RedisTemplate

可以选择创建redis对象:(在里面可以添加一些操作)

@Configuration
@Slf4j  //日志的注解,有它下面的log.info才能使用
public class RedisConfiguration {
@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory){log.info("开始创建redis模板类...");RedisTemplate redisTemplate = new RedisTemplate();        // 设置Key的序列化器,默认为JdkSerializationRedisSerializer       redisTemplate.setKeySerializer(new StringRedisSerializer());             redisTemplate.setConnectionFactory(redisConnectionFactory);return redisTemplate;}
}

测试类:注意,测试类的位置要和引导类处于同一目录下(一般用idea的Spring Initializr创建的测试环境自动给你建立好目录的,但是如果是使用maven自己导入依赖实现的springboot项目,写测试类的时候则需要建立和引导类所处的目录结构,或者在@SpringbootTest()注解里面指定引导类)
在这里插入图片描述

在这里插入图片描述
注意操作redis之前,记得启动redis。

@SpringBootTest
class SpringbootRedisApplicationTests {@Autowiredprivate RedisTemplate redisTemplate;@Testvoid set() {ValueOperations ops = redisTemplate.opsForValue();ops.set("age",41);}@Testvoid get() {ValueOperations ops = redisTemplate.opsForValue();Object age = ops.get("name");System.out.println(age);}@Testvoid hset() {HashOperations ops = redisTemplate.opsForHash();ops.put("info","b","bb");}@Testvoid hget() {HashOperations ops = redisTemplate.opsForHash();Object val = ops.get("info", "b");System.out.println(val);}
}

在操作redis时,需要先确认操作何种数据,根据数据种类得到操作接口。例如使用opsForValue()获取string类型的数据操作接口,使用opsForHash()获取hash类型的数据操作接口,剩下的就是调用对应api操作了。各种类型的数据操作接口如下:
在这里插入图片描述

6.1.2、StringRedisTemplate

由于redis内部不提供java对象的存储格式,因此当操作的数据以对象的形式存在时,会进行转码,转换成字符串格式后进行操作。为了方便开发者使用基于字符串为数据的操作,springboot整合redis时提供了专用的API接口StringRedisTemplate,你可以理解为这是RedisTemplate的一种指定数据泛型的操作API。

@SpringBootTest
public class StringRedisTemplateTest {@Autowiredprivate StringRedisTemplate stringRedisTemplate;@Testvoid get(){ValueOperations<String, String> ops = stringRedisTemplate.opsForValue();String name = ops.get("name");System.out.println(name);}
}

6.1.3、Redis客户端的选择

  1. Spring Boot默认使用的Redis客户端是Lettuce。Lettuce是一个高性能的异步Redis客户端,它基于Netty框架实现了高效的异步通信。它支持连接池和集群模式,并提供了丰富的功能和灵活的配置选项。

    • 在Spring Boot中,你可以通过在配置文件中设置spring.redis.client-type属性来指定使用的Redis客户端。默认情况下,该属性的值是lettuce,即使用Lettuce作为Redis客户端。如果你想使用Jedis作为Redis客户端,可以根据需要切换成指定客户端技术将该属性的值设置为对应的客户端技术,比如jedis。
  2. 切换成jedis客户端技术操作步骤如下:

步骤①:导入jedis坐标

<dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId>
</dependency>

edis坐标受springboot管理,无需提供版本号
步骤②:配置客户端技术类型,设置为jedis

spring:redis:host: localhostport: 6379client-type: jedis
  1. lettcus与jedis区别
    • jedis连接Redis服务器是直连模式,当多线程模式下使用jedis会存在线程安全问题,解决方案可以通过配置连接池使每个连接专用,这样整体性能就大受影响
    • lettcus基于Netty框架进行与Redis服务器连接,底层设计中采用StatefulRedisConnection。 StatefulRedisConnection自身是线程安全的,可以保障并发访问安全问题,所以一个连接可以被多线程复用。当然lettcus也支持多连接实例一起工作

七、redis的两种持久化方式

  1. redis提供了两种持久化的方式,分别是RDB(Redis DataBase)和AOF(Append Only File)。
    • RDB:就是在不同的时间点,将redis存储的数据生成快照并存储到磁盘等介质上;
    • AOF:与RDB相比,则是换了一个角度来实现持久化,那就是将redis执行过的所有写指令记录下来,在下次redis重新启动时,只要把这些写指令从前到后再重复执行一遍,就可以实现数据恢复了。
    • 其实RDB和AOF两种方式也可以同时使用,在这种情况下,如果redis重启的话,则会优先采用AOF方式来进行数据恢复,这是因为AOF方式的数据恢复完整度更高。如果没有数据持久化的需求,也完全可以关闭RDB和AOF方式。这样的话,redis将变成一个纯内存数据库,就像memcache一样。

Redis的使用应该是在Linux环境,这里只是基本了解下Redis的知识。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Pearson correlation coefficient (Pearson’s r) 皮尔森相关系数

此图用的是箱状图&#xff0c;的纵轴是“Pearson’s r”&#xff0c;是实际观测值与机器学习模型预测值之间的相关性 Pearsons f得分&#xff0c;它是一个统计量&#xff0c;用来衡量两个变量之间线性相关性的强度。这个得分可能是用来衡量实际观测值与机器学习模型预测值之间的…

YOLOv8改进 | 检测头篇 | ASFF改进YOLOv8检测头(全网首发)

一、本文介绍 本文给大家带来的改进机制是利用ASFF改进YOLOv8的检测头形成新的检测头Detect_ASFF&#xff0c;其主要创新是引入了一种自适应的空间特征融合方式&#xff0c;有效地过滤掉冲突信息&#xff0c;从而增强了尺度不变性。经过我的实验验证&#xff0c;修改后的检测头…

Tomcat和Servlet

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、Tomcat是什么&#xff1f;1.1下载&#xff1a;1.2 tomcat是什么1.3启动服务器&#xff1a; 二.部署三、Servlet3.1创建项目3.2引入依赖pom.xml的所有代码 3…

Tg-5511cb: tcxo高稳定性+105℃高温

爱普生推的一款TG-5511CB是一种高稳定的TCXO温补晶体振荡器&#xff0c;频率范围十分广泛从 10mhz ~ 54mhz&#xff0c;它的电源电压只需要3.3V&#xff0c;无论是手机还是其他电子设备&#xff0c;都能轻松提供稳定的电力支持。频率/温度特性表现出色&#xff0c;0.28 10^6Ma…

(2023,提示扩展,图像反演,文本到文本生成)自适应文本到图像生成的提示扩展

Prompt Expansion for Adaptive Text-to-Image Generation 公众&#xff1a;EDPJ&#xff08;添加 VX&#xff1a;CV_EDPJ 或直接进 Q 交流群&#xff1a;922230617 获取资料&#xff09; 目录 0. 摘要 3. 提示扩展数据集 3.1 图像审美数据集 3.2 图像到文本反演 3.3 查…

Obsidian笔记软件无公网远程同步数据到群辉Webdav

文章目录 1. 群晖开启Webdav服务2. 群晖安装Cpolar3. 配置Webdav远程地址4. Obsidian 安装Remotely Save5. Obsidian远程连接Webdav6. 固定Cpolar公网地址7. PC和移动端笔记同步演示 Obsidian是一款笔记软件&#xff0c;它基于Markdown&#xff0c;支持Windows、macOS、iOS和An…

个人博客主题 vuepress-hope

文章目录 1. 简介2. 配置2.1 个人博客&#xff0c;社媒链接配置 非常推荐vuepress-hope 1. 简介 下面的我的博客文章的截图 通过md写博客并且可以同步到github-page上 2. 配置 2.1 个人博客&#xff0c;社媒链接配置 配置文件 .vuepress/theme.ts blog: {medias: {BiliB…

计算机毕业设计 基于HTML5+CSS3的在线英语阅读分级平台的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍&#xff1a;✌从事软件开发10年之余&#xff0c;专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精…

C#编程-使用变量

使用变量 请考虑以下场景:您必须创建一个程序,接受来自用户的两个数字并在屏幕上显示着两个数字之和。现在,读取用户提供的数字时,您需要将这些数字存储在内存中的某个位置,以便您能对这些数字执行加操作。您可以使用变量将这些数字存储在内存中。 下图显示了使用变量将…

股票价格预测 | Python实现Autoformer, FEDformer和PatchTST等模型用于股价预测

文章目录 效果一览文章概述环境描述源码设计效果一览 文章概述 Autoformer、FEDformer和PatchTST是一些用于时间序列预测,包括股价预测的模型。它们都是在Transformer模型的基础上进行了改进和扩展,以更好地适应时间序列数据的特点。 Autoformer:Autoformer是一种自适应Tran…

pytorch05:卷积、池化、激活

目录 一、卷积1.1 卷积的概念1.2 卷积可视化1.3 卷积的维度1.4 nn.Conv2d1.4.1 无padding 无stride卷积1.4.2 无padding stride2卷积1.4.3 padding2的卷积1.4.4 空洞卷积1.4.5 分组卷积 1.5 卷积输出尺寸计算1.6 卷积的维度1.7 转置卷积1.7.1 为什么被称为转置卷积1.7.2 nn.Con…

【HDFS联邦(2)】HDFS Router-based Federation官网解读:HDFSRouterFederation的架构、各组件基本原理

文章目录 一. 介绍二、HDFS Router-based Federation 架构1. 示例说明2. Router2.1. Federated interface2.2. Router heartbeat2.3. NameNode heartbeat2.4. Availability and fault toleranceInterfaces 3. Quota management4. State Store 三、部署 ing 本文主要参考官网&am…

JavaScript系列——正则表达式

文章目录 需求场景正则表达式的定义创建正则表达式通过 / 表示式/ 创建通过构造函数创建 编写一个正则表达式的模式使用简单模式使用特殊字符常用特殊字符列表特殊字符组和范围 正则表达式使用代码演示 常用示例验证手机号码合法性 小结 需求场景 在前端开发领域&#xff0c;在…

C语言 指针

C语言学习&#xff01; 目录 文章目录 前言 一、指针是什么&#xff1f; 二、指针变量的大小 三、指针和指针类型 四、指针和函数 五、野指针 5.1野指针成因 5.2 如何规避野指针 六、指针运算 6.1 指针- 整数 6.2 指针-指针 6.3 指针的关系运算 总结 前言 指针理解的2个要点&a…

前端Vue中自定义Popup弹框、按钮及内容的设计与实践

标题&#xff1a;前端Vue中自定义Popup弹框、按钮及内容的设计与实践 一、引言 在Web前端开发中&#xff0c;弹框&#xff08;Popup&#xff09;是一种常见的用户界面元素&#xff0c;用于向用户显示额外的信息或提供额外的功能。然而&#xff0c;标准的弹框往往不能满足所有…

Django学习3——靓号管理

目录 靓号管理 表结构和数据 根据表结构的需求&#xff0c;在models.py中创建类&#xff08;由类生成数据库中的表&#xff09; 在数据库生成表 自己在数据模拟创建一些数据&#xff1a; 靓号列表 新建靓号 编辑靓号 删除靓号 搜索靓号 靓号管理 表结构和数据 根…

DHCP学习记录

目录 客户端向DHCP服务端申请租用IP的4个阶段: 客户端向HDCP服务器续租IP过程: 客户端重新连接租用IP过程: 客户端释放IP 声明: (Dynamic Host Configuration Protocol)动态主机配置协议&#xff0c;客户端向DHCP服务端申请获得ip的一种约定俗成的话语(协议) 手工配置方式…

啊哈c语言——4.10、for隆重登场(一起来找茬)

下面这段代码是求12345678910的值。其中有4个错误&#xff0c; 快来改正吧&#xff01; 改正后&#xff1a; #include <stdio.h> #include <stdlib.h> int main( ) {int i, sum;sum1;for(i1; i<10;i){sumsum*i;}printf("%d", sum);system("paus…

如何在无公网IP环境使用Windows远程桌面Ubuntu

文章目录 一、 同个局域网内远程桌面Ubuntu二、使用Windows远程桌面连接三、公网环境系统远程桌面Ubuntu1. 注册cpolar账号并安装2. 创建隧道&#xff0c;映射3389端口3. Windows远程桌面Ubuntu 四、 配置固定公网地址远程Ubuntu1. 保留固定TCP地址2. 配置固定的TCP地址3. 使用…

appium安装运行报错的解决方案

appium版本2.3 java17 运行报错&#xff1a; Caused by: org.openqa.selenium.SessionNotCreatedException: Could not start a new session. Response code 500. Message: An unknown server-side error occurred while processing the command. Original error: Could not…