中间件:SpringBoot集成Redis
一、Redis简介
Redis是一个开源的、基于内存的数据结构存储系统,它可以用作数据库、缓存和消息中间件。Redis支持多种类型的数据结构,如字符串(strings)、哈希(hashes)、列表(lists)、集合(sets)、有序集合(sorted sets)等,并提供了丰富的命令来操作这些数据。Redis具有高性能、低延迟的特点,并且支持数据持久化、主从复制和集群模式,可以满足各种应用场景的需求。
二、Redis基本使用
在Redis的基本使用中,虽然大部分步骤(如安装、配置、启动、连接)通常不直接涉及Java代码,但你可以使用Java代码来与Redis进行交互。这通常是通过Java客户端库(如Jedis或Lettuce)来实现的。以下是一个简要的总结,包括如何在Java中使用这些库来连接和操作Redis。
一、Windows安装、配置、启动、连接
- 安装:下载Redis的Windows版本,解压到指定目录。
- 配置:修改
redis.windows.conf
文件,根据需要调整配置。 - 启动:在命令行中运行
redis-server.exe redis.windows.conf
。 - 连接:通常使用
redis-cli
命令行工具或可视化工具(如Redis Desktop Manager)进行连接。
二、Java代码与Redis交互
1. 添加依赖
首先,你需要在你的Java项目中添加Jedis或Lettuce的依赖。这里以Maven为例,使用Jedis:
<dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>4.0.1</version>
</dependency>
2. 连接Redis
使用Jedis连接Redis:
import redis.clients.jedis.Jedis; public class RedisExample { public static void main(String[] args) { // 连接到本地的 Redis 服务 Jedis jedis = new Jedis("localhost"); System.out.println("连接成功"); // 设置 Redis 字符串数据 jedis.set("tutorial-key", "Redis tutorial"); // 获取存储的数据并输出 String value = jedis.get("tutorial-key"); System.out.println("存储在 Redis 的字符串为: " + value); // 关闭连接 jedis.close(); }
}
3. 基本操作
以下是一些基本的Redis操作及其对应的Java代码:
- 设置键值对:
jedis.set("key", "value");
- 获取值:
String value = jedis.get("key");
- 哈希操作:
jedis.hset("hashKey", "field1", "value1");
String hashValue = jedis.hget("hashKey", "field1");
- 列表操作:
jedis.lpush("listKey", "element1");
jedis.rpush("listKey", "element2");
List<String> listValues = jedis.lrange("listKey", 0, -1);
- 集合操作:
jedis.sadd("setKey", "member1");
Set<String> setMembers = jedis.smembers("setKey");
- 有序集合操作:
jedis.zadd("sortedSetKey", 1, "one");
jedis.zadd("sortedSetKey", 2, "two");
Set<Tuple> sortedSetValues = jedis.zrangeWithScores("sortedSetKey", 0, -1);
4. 使用可视化工具
虽然Java代码是与Redis交互的主要方式,但可视化工具(如Redis Desktop Manager)仍然非常有用,因为它们提供了直观的界面来查看和编辑Redis数据。你可以在使用Java代码之前或之后,使用这些工具来验证你的操作结果。
总结
在Java中与Redis交互通常涉及使用Jedis或Lettuce这样的客户端库。你需要添加依赖、创建连接对象、执行Redis命令,并在完成后关闭连接。虽然安装、配置和启动Redis服务器本身不涉及Java代码,但你可以使用Java代码来与运行中的Redis实例进行交互。
三、Jedis操作Redis
Jedis是Redis的Java客户端,提供了简单易用的API来操作Redis。使用Jedis之前,需要确保Redis服务已经启动,并且可以通过网络进行连接。Jedis的使用步骤包括导入依赖、建立连接、执行命令和关闭连接等。通过Jedis,可以方便地执行Redis的各种命令,如设置和获取字符串值、操作哈希表、列表和集合等。
四、SpringBoot操作Redis
在SpringBoot中操作Redis,通常使用Spring Data Redis提供的RedisTemplate工具类。RedisTemplate封装了各种对Redis的操作,支持不同的数据类型,并且提供了统一API来操作Redis。在SpringBoot项目中,可以通过添加spring-boot-starter-data-redis依赖来集成Redis,并在配置文件中配置Redis的连接信息。然后,可以通过注入RedisTemplate来操作Redis数据库。
五、SpringBoot集成Redis使用Cache缓存
SpringBoot集成Redis后,可以利用Redis作为缓存来提高应用的性能。Spring提供了@Cacheable注解来支持缓存功能,可以将方法的返回值缓存到Redis中,以便在下次调用时快速获取结果。在使用缓存时,需要配置缓存管理器(CacheManager)和缓存解析器(CacheResolver),并指定缓存的名称和过期时间等参数。通过合理配置和使用缓存,可以显著减少数据库的访问压力,提高应用的响应速度。
以下是一个简单的SpringBoot集成Redis并使用Cache缓存的示例代码:
<!-- 在pom.xml中添加spring-boot-starter-data-redis依赖 -->
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
# 在application.yml中配置Redis的连接信息
spring: redis: host: localhost port: 6379 password: yourpassword # 如果有密码的话 database: 0 jedis: pool: max-active: 8 # 最大连接数 max-idle: 4 # 最大空闲连接 min-idle: 0 # 最小空闲连接
// 配置RedisCacheManager
@Configuration
@EnableCaching
public class RedisCacheConfig { @Bean public RedisCacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) { RedisCacheConfiguration cacheConfiguration = RedisCacheConfiguration.defaultCacheConfig() .entryTtl(Duration.ofMinutes(10)) // 设置缓存过期时间 .disableCachingNullValues(); // 禁止缓存空值 return RedisCacheManager.builder(redisConnectionFactory) .cacheDefaults(cacheConfiguration) .build(); }
}
// 使用@Cacheable注解来缓存方法结果
@Service
public class UserService { @Cacheable(value = "users", key = "#id") public User getUserById(Long id) { // 模拟从数据库中获取用户信息 return new User(id, "John Doe"); }
}
在上面的示例中,我们首先在pom.xml中添加了spring-boot-starter-data-redis依赖,然后在application.yml中配置了Redis的连接信息。接着,我们创建了一个RedisCacheConfig配置类来配置RedisCacheManager。最后,我们在UserService中使用@Cacheable注解来缓存getUserById方法的结果。这样,当多次调用getUserById方法时,如果参数相同,则可以直接从缓存中获取结果,而无需再次访问数据库。
综上所述,SpringBoot集成Redis可以极大地提高应用的性能和灵活性。通过合理配置和优化Redis,可以更好地利用Redis来存储和访问数据,满足各种应用场景的需求。
相关文章:
中间件:SpringBoot集成Redis
一、Redis简介 Redis是一个开源的、基于内存的数据结构存储系统,它可以用作数据库、缓存和消息中间件。Redis支持多种类型的数据结构,如字符串(strings)、哈希(hashes)、列表(lists)…...

数据中心建设方案,大数据平台建设,大数据信息安全管理(各类资料原件)
第一章 解决方案 1.1 建设需求 1.2 建设思路 1.3 总体方案 信息安全系统整体部署架构图 1.3.1 IP准入控制系统 1.3.2 防泄密技术的选择 1.3.3 主机账号生命周期管理系统 1.3.4 数据库账号生命周期管理系统 1.3.5 双因素认证系统 1.3.6 数据库审计系统 1.3.7 数据脱敏…...

TDD(测试驱动开发)是否已死?
Rails 大神、创始人 David Heinemeier Hansson 曾发文抨击TDD。 TDD is dead. Long live testing. (DHH) 此后, Kent Beck、Martin Fowler、David Hansson 三人就这个观点还举行了系列对话(辩论) Is TDD Dead? 笔者作为一个多年在软件测试领域摸索的人&…...
Debezium系列之:实时从TDengine数据库采集数据到Kafka Topic
Debezium系列之:实时从TDengine数据库采集数据到Kafka Topic 一、认识TDengine二、TDengine Kafka Connector三、什么是 Kafka Connect?四、前置条件五、安装 TDengine Connector 插件六、启动 Kafka七、验证 kafka Connect 是否启动成功八、TDengine Source Connector 的使用…...
数据结构(一)顺序表
顺序表的概念及结构 线性表 线性表是具有相同特征的数据结构的集合 物理结构 不一定连续 逻辑结构 连续 顺序表 顺序表是线性表的一种,顺序表的底层是数组 物理结构 连续 逻辑结构 连续 顺序表分类 静态顺序表 struct SeqList {int a…...
如何在 Jupyter Notebook 执行和学习 SQL 语句(中)
1. 基础SQL操作 创建数据库和表,插入数据: import sqlite3# 创建SQLite数据库并连接 conn sqlite3.connect(example.db) cursor conn.cursor()# 创建用户表 cursor.execute(CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY AUTOINCREMENT…...

AutosarMCAL开发——基于EB Wdg驱动
目录 一、Wdg原理以及作用1.看门狗类型2.看门狗功能特点3.看门狗工作模式4.看门狗超时响应5.看门狗寄存器 二、WDG模块EB配置(TC3X系列MCU)1.WDG通用配置:2.WDG设置:3.时钟资源分配4.配置STM IRQ中断5.配置触发执行动作࿱…...

Linux(1. 基本操作_命令)
目录 关于超级用户root: root用户可以做什么? 避免灾难: 格式约定: 浏览硬盘: 命令行补全和通配符: 命令行补全: 通配符: 常用基本命令: 查看目录和文件ÿ…...

难点:Linux 死机定位(进程虚拟地址空间耗尽)
死机定位(进程虚拟地址空间耗尽) 一、死机现象 内存富裕,但内存申请失败。 死机时打印: 怀疑是: 1、内存碎片原因导致。 2、进程虚拟地址空间耗尽导致。 3、进程资源限制导致。 二、内存碎片分析 1、理论知识:如何分析内存碎片化情况 使用 /proc/buddyinfo: /proc/…...
小米路由器刷机istoreOS,愉快上网
istoreOS与openwrt openwrt是一个开源的路由器系统,市场上所有小米路由器的内部系统都是基于openwrt进行二次开发形成的,做了硬件适配和功能上的阉割,不太好用。 istoreos是小宝团队基于openwrt制作的一个发行版,更适合中国宝宝体质。页面简约华丽,完全兼容开源openwrt的…...
微信小程序 - 01 - 一些补充和注意点(补充ing...)
目录 一、节流二、在一个发请求的函数中,只有发生下拉动作,才执行关闭下拉代码 最近在学微信小程序,把学习过程中的一些补充和注意点总结一下,内容会比较简单,因为只涉及基础知识,供个人参考 一、节流 情…...

微服务实战——登录(普通登录、社交登录、SSO单点登录)
登录 1.1. 用户密码 PostMapping("/login")public String login(UserLoginVo vo, RedirectAttributes redirectAttributes, HttpSession session){R r memberFeignService.login(vo);if(r.getCode() 0){MemberRespVo data r.getData("data", new Type…...

windows 安装 ElasticSearch
1、下载安装包 下载地址:https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-8.14.3-windows-x86_64.zip ElasticSearch 目录结构如下: 2、配置JDK环境 ES比较耗内存,建议虚拟机4G或以上内存,jvm1g以上的内存分…...
Oracle Linux 9 (CentOS Stream 9) 安装 node.js 20
Oracle Linux 的 node 默认版本为 16,运行dnf update也无法改变大版本,还需要进行额外操作1 查看支持的版本 sudo dnf module list nodejs输出如下 Last metadata expiration check: 3:37:22 ago on Fri 11 Oct 2024 09:08:18 PM JST. Oracle Linux 9 Ap…...

【Axure安装包与汉化包附带授权证书】
一、下载Axure安装包与汉化包附带授权证书 1.下载汉化包 【快传】: 点击链接即可保存 2.解压安装包 解压下载好的压缩包,能看到有lang也就是汉化包,AxureRP-Setup-RC.exe 也就是Axure9的安装程序,以及汉化说明和授权码。 二、安装Axure9…...
SSH隧道验证的原理及实现例子
SSH 隧道验证原理详解 **SSH 隧道(SSH Tunneling)**是通过 SSH 协议将数据在客户端和服务器之间加密传输的一种技术。它可以在不安全的网络上创建一个安全的、加密的通道,用于传输各种数据,例如通过不安全的网络远程登录、传输文…...
[计算机视觉]chapter1
一、什么是计算机视觉 计算机视觉就是用计算机编程,并设计算法来理解在这些图像中有什么。计算机视觉是一门研究如何使机器“看”的科学,更进一步的说,就是是指用摄影机和电脑代替人眼对目标进行识别、跟踪和测量等机器视觉,并进一步做图形处理,使电脑处理成为更适合人眼…...

RTKLIB学习记录【postpos、execses_b、execses_r】
本文主要记录对RTKLIB源码中postpos、execses_b、execses_r 函数的源码解读,不涉及其中的天线、星历等文件读取的内容,且为个人理解,如果有误,欢迎交流讨论。 一、postpos 函数部分 /rxn2rtkp函数 → postpos函数传递参数&#x…...

docker,docker-desktop,docker-compose download
docker docker-compose download 百度网盘获取离线包链接release-notes 参考dockerdocker-composewlspowershell...
C#_带参数的委托进入队列执行
我们经常会遇到一些函数多个地方调用,但是只能单独执行的就需要把它放到队列中执行。 1.创建对应该方法的委托(传参和回参类型需要一致)。 //委托: public delegate void CameraTaskDelegate(byte cs, ref byte[] buffer);//对应函数: public void CameraSettingRead(by…...

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型
摘要 拍照搜题系统采用“三层管道(多模态 OCR → 语义检索 → 答案渲染)、两级检索(倒排 BM25 向量 HNSW)并以大语言模型兜底”的整体框架: 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后,分别用…...

业务系统对接大模型的基础方案:架构设计与关键步骤
业务系统对接大模型:架构设计与关键步骤 在当今数字化转型的浪潮中,大语言模型(LLM)已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中,不仅可以优化用户体验,还能为业务决策提供…...
conda相比python好处
Conda 作为 Python 的环境和包管理工具,相比原生 Python 生态(如 pip 虚拟环境)有许多独特优势,尤其在多项目管理、依赖处理和跨平台兼容性等方面表现更优。以下是 Conda 的核心好处: 一、一站式环境管理:…...
云原生核心技术 (7/12): K8s 核心概念白话解读(上):Pod 和 Deployment 究竟是什么?
大家好,欢迎来到《云原生核心技术》系列的第七篇! 在上一篇,我们成功地使用 Minikube 或 kind 在自己的电脑上搭建起了一个迷你但功能完备的 Kubernetes 集群。现在,我们就像一个拥有了一块崭新数字土地的农场主,是时…...

CTF show Web 红包题第六弹
提示 1.不是SQL注入 2.需要找关键源码 思路 进入页面发现是一个登录框,很难让人不联想到SQL注入,但提示都说了不是SQL注入,所以就不往这方面想了 先查看一下网页源码,发现一段JavaScript代码,有一个关键类ctfs…...

简易版抽奖活动的设计技术方案
1.前言 本技术方案旨在设计一套完整且可靠的抽奖活动逻辑,确保抽奖活动能够公平、公正、公开地进行,同时满足高并发访问、数据安全存储与高效处理等需求,为用户提供流畅的抽奖体验,助力业务顺利开展。本方案将涵盖抽奖活动的整体架构设计、核心流程逻辑、关键功能实现以及…...

最新SpringBoot+SpringCloud+Nacos微服务框架分享
文章目录 前言一、服务规划二、架构核心1.cloud的pom2.gateway的异常handler3.gateway的filter4、admin的pom5、admin的登录核心 三、code-helper分享总结 前言 最近有个活蛮赶的,根据Excel列的需求预估的工时直接打骨折,不要问我为什么,主要…...
LLM基础1_语言模型如何处理文本
基于GitHub项目:https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken:OpenAI开发的专业"分词器" torch:Facebook开发的强力计算引擎,相当于超级计算器 理解词嵌入:给词语画"…...
Spring AI与Spring Modulith核心技术解析
Spring AI核心架构解析 Spring AI(https://spring.io/projects/spring-ai)作为Spring生态中的AI集成框架,其核心设计理念是通过模块化架构降低AI应用的开发复杂度。与Python生态中的LangChain/LlamaIndex等工具类似,但特别为多语…...

HDFS分布式存储 zookeeper
hadoop介绍 狭义上hadoop是指apache的一款开源软件 用java语言实现开源框架,允许使用简单的变成模型跨计算机对大型集群进行分布式处理(1.海量的数据存储 2.海量数据的计算)Hadoop核心组件 hdfs(分布式文件存储系统)&a…...