redis在项目中运用(基础)

mysql学完命令之后,学过jdbc。

redis也要使用Java连接redis数据库

1.Jedis

2.RedisTemplate[重点]

1、Jedis【了解】

jedis是redis的java版本的客户端实现,jedis中提供了针对redis命令的操作

1.1导入jar文件

Maven方式

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

测试

入门案例

package com.qf.day63_redis.jedis;
​
import redis.clients.jedis.Jedis;
​
/*** ---厚德载物---** @Author wangbo* @Date 2024/10/11* @Desc 人的一生适可而止*/
public class App {public static void main(String[] args) {//1.创建jedis对象Jedis jedis = new Jedis("127.0.0.1", 6379);System.out.println(jedis);//2.设置一个数据jedis.set("likeNum", "100");//.3获取数据String s = jedis.get("likeNum");System.out.println(s);}
}
​

像一个问题? windows版本的redis 启动时候默认是没有密码的

如何设置密码启动?

1.找到redis.window.conf

找到503行 requirepass root(自己定义的密码)

2.启动 使用命令启动

redis-server redis.windows.conf

package com.qf.day63_redis.jedis;
​
import redis.clients.jedis.Jedis;
​
/*** ---厚德载物---** @Author wangbo* @Date 2024/10/11* @Desc 人的一生适可而止*/
public class App {public static void main(String[] args) {//1.创建jedis对象Jedis jedis = new Jedis("127.0.0.1", 6379);//1.1设置密码 如果有密码启动的时候  才取设置的!!!jedis.auth("root");System.out.println(jedis);//2.设置一个数据jedis.set("likeNum", "100");//.3获取数据String s = jedis.get("likeNum");System.out.println(s);}
}
1.2JedisPool

Jedis对象并不是线程安全的,在多线程下使用同一个Jedis对象会出现并发问题。为了避免每次使用Jedis对象时都需要重新构建,Jedis提供了JedisPool。JedisPool是基于Commons Pool 2实现的一个线程安全的连接池。如果使用jedis连接池,需要commons-pool2的jar包

package com.qf.day63_redis.jedis;
​
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
​
/*** ---厚德载物---** @Author wangbo* @Date 2024/10/11* @Desc 人的一生适可而止*/
public class JedisUtils {//1.声明连接池的对象private static JedisPool jedisPool = null;static {//2.创建redisPool连接池的配置对象JedisPoolConfig config = new JedisPoolConfig();//最多与多少个jedis对象config.setMaxTotal(50);//最多有多少空闲的jedis对象config.setMaxIdle(20);//最大等待时间config.setMaxWaitMillis(5000);//检查连接的有效性config.setTestOnBorrow(true);
​//第二个参数:redis服务器的ip//第三个参数:端口//第四个参数:连接服务器的超时时间//第五个参数:密码//创建redis连接池对象jedisPool = new JedisPool(config, "127.0.0.1", 6379, 1000, "root");}//封装好一个方法,获取Jedis对象public static Jedis getJedis() {Jedis jedis = jedisPool.getResource();return jedis;}//jedis放回池子中public  static void close(Jedis jedis) {jedis.close();//}
}
​

2、在springboot 中集成redis

2.1RedisTemplate

spring-data-redis的jar中,提供在spring应用中通过简单的配置访问redis服务的功能,它对reids底层开发包进行了高度封装。

针对reids的操作,包中提供了RedisTemplate类和StringRedisTemplate类,其中StringRedisTemplate是RedisTemplate的子类,该类只支持key和value为String的操作

2.2主要封装接口

RedisTemplate针对不同数据类型的操作进行封装,将同一类型操作封装为Operation接口

ValueOperations:简单K-V操作,获取方式 redisTemplate.opsForValue();

SetOperations:set类型数据操作,获取方式 redisTemplate.opsForSet();

ZSetOperations:zset类型数据操作,获取方式 redisTemplate.opsForZSet();

HashOperations:针对hash类型的数据操作, 获取方式 redisTemplate.opsForHash();

ListOperations:针对list类型的数据操作,获取方式 redisTemplate.opsForList();

2.3序列化策略

StringRedisTemplate默认采用的是String的序列化策略,保存的key和value都是采用此策略序列化保存的。

RedisTemplate默认采用的是JDK的序列化策略,保存的key和value都是采用此策略序列化保存的。

GenericToStringSerializer: 可以将任何对象泛化为字符串并序列化

Jackson2JsonRedisSerializer: 跟JacksonJsonRedisSerializer实际上是一样的

JacksonJsonRedisSerializer: 序列化object对象为json字符串

JdkSerializationRedisSerializer: 序列化java对象(被序列化的对象必须实现Serializable接口)

StringRedisSerializer: 简单的字符串序列化

GenericToStringSerializer:类似StringRedisSerializer的字符串序列化

GenericJackson2JsonRedisSerializer:类似Jackson2JsonRedisSerializer,但使用时构造函数不用特定的类

【注意】: 存储数据的时候指定 序列化策略

2.4导入jar
<!-- redis -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
​
<!-- pool 对象池 -->
<dependency><groupId>org.apache.commons</groupId><artifactId>commons-pool2</artifactId>
</dependency>

在SpringBoot 1.5.x版本默认的Redis客户端是Jedis实现的,SpringBoot 2.x版本默认客户端是用lettuce实现的

2.5yml中配置
  # redis 配置spring:redis:# 地址host: 127.0.0.1# 端口,默认为6379port: 6379# 数据库索引database: 0# 密码password: root# 连接超时时间timeout: 10slettuce:pool:# 连接池中的最小空闲连接min-idle: 0# 连接池中的最大空闲连接max-idle: 8# 连接池的最大数据库连接数max-active: 8# #连接池最大阻塞等待时间(使用负值表示没有限制)max-wait: -1ms
2.6redis配置类

SpringBoot自动在容器中创建了RedisTemplate对象和StringRedisTemplate对象。但是,RedisTemplate的泛型是<Object,Object>,进行数据处理时比价麻烦,我们需要自定义一个RedisTemplate对象

package com.qf.day63_redis.config;
​
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;
​
import javax.annotation.Resource;
​
/*** ---厚德载物---** @Author wangbo* @Date 2024/10/11* @Desc 人的一生适可而止*/
@Configuration
public class RedisConfig {@Resource//lettuceConnectionFactory  创建lettuce对象的private LettuceConnectionFactory lettuceConnectionFactory;//自定义redisTemplate对象@Beanpublic RedisTemplate<String,Object> redisTemplate() {RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
​StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();GenericJackson2JsonRedisSerializer jackson2JsonRedisSerializer = new GenericJackson2JsonRedisSerializer();//key采用String的序列化方式redisTemplate.setKeySerializer(stringRedisSerializer);// value序列化方式采用jacksonredisTemplate.setValueSerializer(jackson2JsonRedisSerializer);// hash的key也采用String的序列化方式redisTemplate.setHashKeySerializer(stringRedisSerializer);// hash的value序列化方式采用jacksonredisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);redisTemplate.setConnectionFactory(lettuceConnectionFactory);return redisTemplate;}
}
​

直接测试

package com.qf.day63_redis;
​
import com.qf.day63_redis.entity.User;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.redis.core.RedisTemplate;
​
import javax.annotation.Resource;
import java.util.ArrayList;
import java.util.List;
​
@SpringBootTest
class Day63RedisApplicationTests {@Resourceprivate RedisTemplate<String, Object> redisTemplate;
​@Testvoid contextLoads() {redisTemplate.opsForValue().set("viewNum", 1000);Integer num = (Integer)redisTemplate.opsForValue().get("viewNum");System.out.println(num);}@Testvoid test1 () {User user = new User();user.setName("狗蛋");user.setAge(21);redisTemplate.opsForValue().set("user", user);//{"@class":"com.qf.day63_redis.entity.User","name":"狗蛋","age":21}
​}@Testvoid test2 () {User user = new User();user.setName("狗蛋");user.setAge(21);User user1 = new User();user1.setName("狗蛋1");user1.setAge(22);User user2 = new User();user2.setName("狗蛋2");user2.setAge(22);List<User> list = new ArrayList<>();list.add(user);list.add(user1);list.add(user2);redisTemplate.opsForValue().set("userList", list);List<User> list1  = (List<User>)redisTemplate.opsForValue().get("userList");System.out.println(list1);////["java.util.ArrayList",[{"@class":"com.qf.day63_redis.entity.User","name":"狗蛋","age":21},{"@class":"com.qf.day63_redis.entity.User","name":"狗蛋1","age":22},{"@class":"com.qf.day63_redis.entity.User","name":"狗蛋2","age":22}]]
​}
​
​
}
​

发现对redis数据库操作的时候,还得写ops方法 再根set get del 操作

有一个想法,把这些操作封装到 一个类中,直接使用类调用方法即可

RedisUtils工具类

工具类的第一种写法:

package com.qf.day63_redis.utils;
​
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;
​
import javax.annotation.Resource;
​
/*** ---厚德载物---** @Author wangbo* @Date 2024/10/11* @Desc 人的一生适可而止*/
@Component//把工具类放到了容器中了
public class RedisUtils {@Resourceprivate RedisTemplate<String, Object> redisTemplate;//直接注入public static void setValue (String key, Object value) {redisTemplate.opsForValue().set(key, value);}
}
​

使用

@Testvoid test4 () {User user1 = new User();user1.setName("狗蛋1");user1.setAge(22);redisUtils.setValue("user1", user1);}
​

工具类的第二种写法:

就是方法中加了static修饰符 无法 在RedisUtils中注入redisTemplate的对象的

只能借助于一个叫SpringBeanUtils 自己写的工具类型

package com.qf.day63_redis.utils;
import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;
/***---厚德载物---*@Author wangbo*@Date 2024/10/11*@Desc* 人的一生适可而止**/
​
​
​
​
@Component
public class SpringBeanUtils implements ApplicationContextAware {
​/*** Spring应用上下文对象*/private static ApplicationContext applicationContext = null;
​/*** 注入上下文对象** @param applicationContext* @throws BeansException*/@Overridepublic void setApplicationContext(ApplicationContext applicationContext) throws BeansException {SpringBeanUtils.applicationContext = applicationContext;}
​/*** 根据名称获取bean对象** @param name* @param <T>* @return* @throws BeansException*/public static <T> T getBean(String name) {return (T) applicationContext.getBean(name);}
​/*** 根据类型获取bean对象** @param clz* @param <T>* @return*/public static <T> T getBean(Class<T> clz) {T result = (T) applicationContext.getBean(clz);return result;}
​
}
​

第二种写法的工具类

package com.qf.day63_redis.utils;
​
import org.springframework.data.redis.core.RedisTemplate;
​
/*** ---厚德载物---** @Author wangbo* @Date 2024/10/11* @Desc 人的一生适可而止*/
public class RedisUtils1 {//不要使用@Resource注入redisTemplate这个对象了//但是需要redisTemplate对象  咋办? 写一个工具类 获取bean对象的工具类private static  RedisTemplate<String , Object> redisTemplate = SpringBeanUtils.getBean("redisTemplate");
​public static  void setValue (String key, Object value) {redisTemplate.opsForValue().set(key, value);}
}
​

测试

@Test
void test5 () {User user1 = new User();user1.setName("xixi");user1.setAge(25);RedisUtils1.setValue("user2", user1);
}

项目中杂加redis

1.导包

2.yml文件

2.配置类

3.工具类型

以上全部黏贴复制!!!!

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

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

相关文章

SoC芯片中Clock Gen和Reset Gen的时钟树综合

社区目前已经开设了下面列举的前四大数字后端实战课程&#xff0c;均为直播课&#xff0c;且均是小编本人亲自授课&#xff01;遇到项目问题&#xff0c;都可以远程一对一指导解决具体问题。小编本人是一线12年后端经验的数字后端工程师。想找一线IC后端技术专家亲自带你做后端…

【C语言】动态内存管理(下)

本篇博客将讲解以下知识&#xff1a; 1、calloc和realloc 2、常见的动态内存错误 1、calloc和realloc &#xff08;1&#xff09;calloc C语言中还提供了一个函数叫calloc&#xff0c;calloc也用来动态内存分配 calloc函数原型&#xff1a; void* calloc(size_t num, …

Flask如何实现前后端分离项目

在现代Web开发中&#xff0c;前后端分离是一种常见的架构模式&#xff0c;其中前端和后端分别独立开发和部署&#xff0c;通过API进行通信。Flask作为后端框架&#xff0c;可以很容易地与前端框架&#xff08;如React、Vue.js或Angular&#xff09;配合使用来实现前后端分离。以…

配置 @ 路径别名,优化小程序访问路径

配置 路径别名&#xff0c;优化小程序访问路径 在开发大型小程序时&#xff0c;我们通常会采用分包策略来优化加载速度和用户体验。然而&#xff0c;这种分包方式往往会导致访问小程序根目录下文件的路径变得冗长而复杂。为了简化这些路径&#xff0c;我们可以借鉴 Vue 中的做…

标准库、STL、编译参数、正则表达式

标准库 标准库减少了不同程序员对编程语言语法语义的疑惑。 不同语言的标准库 C语言有标准库libc, 最新的Windows系统已更新为ucrt, 可在PC/移动设备共享crt. 相比C语言&#xff0c;C除了有标准C运行时库&#xff0c;增加了STL. STL 写了太多的不同参数类型的加法函数&#xff…

Python 入门(二、什么是 Python 的虚拟环境)

Python 入门第二课 &#xff0c;Python 的虚拟环境...... by 矜辰所致前言 本来以为环境搭建好了&#xff0c;就直接开始敲代码了&#xff0c;但是一直看到一个专业词汇&#xff1a;虚拟环境。 对于习惯了嵌入式 C 语言开发博主来说&#xff0c;一开始确实有点不明白&#xf…

centos celery 日志管理

celery经常会产生大量日志&#xff0c;长时间累计下来会对服务器造成一定的压力 1 配置 logrotate 进行日志拆分 logrotate 是 Linux 系统中常用的日志管理工具。我们将使用它来管理 Celery 的日志文件&#xff0c;确保日志文件不会无限增长&#xff0c;并定期拆分、归档和删…

Spring集成Redisson及存取几种基本类型数据

目录 一.什么是Redisson 二.为什么要使用Redisson 三.Spring集成Redisson 1.添加依赖 2.添加配置信息 3.添加redisson配置类 四.Redisson存取各种类型数据 1.字符串(String类型) 存储 获取 2.object对象类型 1.实体类信息 2.存储 3.获取 3.List集合类型 第一种…

在java 中如何实现执行linux命令,通过post接口代理出来?

接口方式输入命令得返回结果 public AjaxResult doPost(HttpServletRequest request, HttpServletResponse response, String command) throws ServletException, IOException {// 设置响应内容类型 text/plain // response.setContentType("application/json"…

【Python】Qwen-VL-7B box

VLLM-Qwen2-VL-7B-Instruct import cv2# 读取图像 image_path haibaoA.png # 替换为图像的路径 image cv2.imread(image_path)# 定义框的坐标 (x1, y1) 是左上角&#xff0c;(x2, y2) 是右下角 x1, y1 200, 550 # 左上角坐标 x2, y2 799, 750 # 右下角坐标 h, w image.…

Unite Shanghai 2024 团结引擎专场 | 团结引擎 OpenHarmony 工程剖析

在 2024 年 7 月 24 日的 Unite Shanghai 2024 团结引擎专场演讲中&#xff0c;Unity中国 OpenHarmony 技术负责人刘伟贤对团结引擎导出的 OpenHarmony 工程进行了细节剖析&#xff0c;详细讲解 XComponent 如何与引擎结合&#xff0c;UI 线程和引擎线程的关联以及 ts/ets 的代…

ijkMediaPlayer+ TextureView 等比全屏播放视频(避免拉伸)

TextureView默认以fitxy的方式加载surface数据&#xff0c;如果需要等比全屏播放视频&#xff0c;避免拉伸&#xff0c;可以采用Matrix对TextureView进行变换 废话不多说&#xff0c;直接上代码 public class BaseIjkPlayer implements TextureView.SurfaceTextureListener{/…

smbms项目(1)

目录 一、项目搭建准备工作 二、登录功能实现 三、注销功能实现 四、登录拦截实现 一、项目搭建准备工作 1、搭建一个maven web项目 2、配置Tomcat 3、测试项目是否能够跑起来 4、导入项目中会遇到的jar包&#xff08;servlet、jsp、mysql驱动、jstl、standard&#xf…

python+大数据+基于Spark的共享单车数据存储系统【内含源码+文档+部署教程】

博主介绍&#xff1a;✌全网粉丝10W,前互联网大厂软件研发、集结硕博英豪成立工作室。专注于计算机相关专业毕业设计项目实战6年之久&#xff0c;选择我们就是选择放心、选择安心毕业✌ &#x1f345;由于篇幅限制&#xff0c;想要获取完整文章或者源码&#xff0c;或者代做&am…

Golang | Leetcode Golang题解之第464题我能赢吗

题目&#xff1a; 题解&#xff1a; func canIWin(maxChoosableInteger, desiredTotal int) bool {if (1maxChoosableInteger)*maxChoosableInteger/2 < desiredTotal {return false}dp : make([]int8, 1<<maxChoosableInteger)for i : range dp {dp[i] -1}var dfs …

浙江省发规院产业发展研究所调研组莅临迪捷软件考察调研

2024年10月10日下午&#xff0c;浙江省发展与规划院产业发展研究所调研组一行莅临迪捷软件考察调研&#xff0c;绍兴市府办、区发改、区经信、迪荡街道等相关领导陪同。 调研组一行参观了迪捷软件的展厅与办公区&#xff0c;深入了解了迪捷软件的公司发展历程、运营状况、产品…

Ubuntu 上使用 Nginx 实现反向代理并启用 HTTPS(详细教程)

拒绝使用宝塔&#xff0c;虽然宝塔很好用方便&#xff0c;但是他非常占用资源&#xff0c;所以我正在尝试转换我使用服务器的方式&#xff0c;通过命令来才做这些&#xff0c;下面是我的详细步骤。 在这篇教程中&#xff0c;我们将详细介绍如何在 Ubuntu 系统上使用 Nginx 搭建…

【论文#码率控制】ADAPTIVE RATE CONTROL FOR H.264

目录 摘要1.前言2.基本知识2.1 蛋鸡悖论2.2 基本单元的定义2.3 线性MAD预测模型 3.GOP级码率控制3.1 总比特数3.2 初始化量化参数 4.帧级码率控制4.1 非存储图像的量化参数4.2 存储图像的目标比特 5.基本单元级码率控制6.实验结果7.结论 《ADAPTIVE RATE CONTROL FOR H.264》 A…

go clean command

文章目录 1.简介2.格式3.选项4.示例5.应用场景6.小结参考文献 1.简介 在 Go 语言的开发过程中&#xff0c;管理依赖和构建缓存是非常重要的。随着项目的迭代&#xff0c;旧的缓存和不再需要的依赖可能会影响构建的效率和准确性。 Go 提供了一个非常实用的命令 go clean&#…

第J5周:DenseNet+SE-Net实战(TensorFlow版)

>- **&#x1f368; 本文为[&#x1f517;365天深度学习训练营]中的学习记录博客** >- **&#x1f356; 原作者&#xff1a;[K同学啊]** &#x1f4cc; 本周任务&#xff1a; ●1. 在DenseNet系列算法中插入SE-Net通道注意力机制&#xff0c;并完成猴痘病识别&#xff0…