Redis学习笔记--002

Redis的JAVA客户端

文章目录

  • Redis的JAVA客户端
    • 一、Redis的Java客户端的种类
    • 二、Jedis
      • 2.1、使用步骤
      • 2.2、Jedis连接池
    • 三、[SpringDataRedis](https://spring.io/projects/spring-data-redis)
      • 3.1、介绍
      • 3.2、RedisTemplate
      • 3.3、SpringDataRedis使用步骤
      • 3.4、SpringDataRedis的序列化方式
    • 四、StringRedisTemplate
      • 4.1、解决方法
      • 4.2、**ObjectMapper介绍**
      • 4.3、StringRedisTemplate类
    • 五、其它结构的使用

一、Redis的Java客户端的种类

在这里插入图片描述

二、Jedis

Jedis是一个用于连接和与Redis服务器进行交互的Java客户端库。Redis是一个高性能的内存数据存储系统,Jedis允许Java应用程序通过简单的API与Redis进行通信。

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

2.1、使用步骤

  1. 获取Jedis连接
//设置主机地址和端口号
Jedis jedis = new Jedis("192.168.74.1xx", 6379);
  1. 给Jedis设置redis密码
// 设置密码认证
jedis.auth("123456");
  1. 操作
HashMap<String,String> map=new HashMap<>();map.put("id","1");map.put("name","radan");jedis.hset("user:1",map);System.out.println(jedis.hgetAll("user:1"));
  1. 释放连接
jedis.close();

2.2、Jedis连接池

Jedis本身就是线程不安全的,并且频繁的创建和销毁会有性能的损耗,因此推荐使用Jedis连接池代替Jedis的直连方式。(JedisPool)

JedisConnectionFactory 连接池配置类

public class JedisConnectionFactory {private static JedisPool jedisPool = null;static {// 配置连接池JedisPoolConfig jedisPoolConfig=new JedisPoolConfig();// 最大连接数jedisPoolConfig.setMaxIdle(8);// 最大空闲连接jedisPoolConfig.setMaxIdle(8);// 最小空闲连接jedisPoolConfig.setMinIdle(0);// 设置最长等待时间   msjedisPoolConfig.setMaxWaitMillis(200);jedisPool = new JedisPool(jedisPoolConfig,"192.168.74.128",6379);}// 获取Jedis对象public static Jedis getJedis(){return jedisPool.getResource();}public static void closeJedis(){jedisPool.close();}   
}

三、SpringDataRedis

3.1、介绍

Spring Data Redis是Spring框架的一个模块,用于简化在Java应用程序中与Redis数据库进行交互的过程。它提供了高级别的抽象和易于使用的API,使得在Spring应用中使用Redis变得更加容易。

Spring Data Redis的一些关键特点和用途

  1. Redis操作抽象化: Spring Data Redis抽象了与Redis数据库的交互,允许你以面向对象的方式操作数据。你可以将Java对象存储在Redis中,而不必担心底层的Redis命令。

  2. 注解支持: Spring Data Redis支持注解,使得在Java类中定义Redis数据模型更加方便。你可以使用注解来标记实体类、字段和方法,以指定它们与Redis数据之间的映射关系。

  3. 连接池管理: Spring Data Redis集成了连接池管理,确保有效地管理Redis连接。这有助于提高性能和资源利用率。

  4. 声明式事务: 你可以使用Spring的声明式事务管理来确保Redis操作的一致性。这使得在多个Redis命令之间进行原子性操作更加容易。

  5. 缓存支持: Spring Data Redis还提供了与Spring框架的缓存抽象集成使得可以轻松地将Redis用作应用程序的缓存存储。

  6. 查询支持: 该模块允许你使用Spring表达式语言(SpEL)构建自定义查询,以根据不同的条件检索数据。

  7. Pub/Sub支持: Spring Data Redis支持发布/订阅模式,允许你创建消息发布者和订阅者,以便实现实时消息传递。

3.2、RedisTemplate

SpringDataRedis中提供了RedisTemplate工具类,其中封装了各种对Redis的操作。并且将不同数据类型的操作API封装到了不同的类型当中:

在这里插入图片描述

3.3、SpringDataRedis使用步骤

SpringBoot已经提供了对SpringBootDataRedis的支持,使用非常方便:

  1. 引入依赖
   <!--   redis依赖     --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency><!--   连接池依赖    --><dependency><groupId>org.apache.commons</groupId><artifactId>commons-pool2</artifactId><version>2.11.1</version></dependency>
  1. 配置文件
spring:redis:host: 192.168.74.128port: 6379password: 123456lettuce:pool:max-active: 8 # 最大连接max-idle: 8 # 最大空闲连接max-wait: 100  #  最小等待时间min-idle: 0 # 连接等待时间
  1. 注入RedisTemplate
   @Autowiredprivate RedisTemplate redisTemplate;
  1. 测试
    void test001(){//  插入一条数据redisTemplate.opsForValue().set("name","李四");//  读取一条数据Object name = redisTemplate.opsForValue().get("name");System.out.println("name="+name);}

在这里插入图片描述
解决方法

在这里插入图片描述

3.4、SpringDataRedis的序列化方式

可以自定义RedisTemplate的序列化方式,代码如下:

  1. 引入依赖
       <dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId></dependency>
  1. 编写配置类

要求RedisTemplate对象的键使用String类型,值使用Object对象类型

@Configuration
public class RedisConfig {@Beanpublic RedisTemplate<String,Object> redisTemplate(RedisConnectionFactory connectionFactory){//  创建RedisTemplate对象RedisTemplate<String,Object> redisTemplate = new RedisTemplate<>();//  设置连接工厂redisTemplate.setConnectionFactory(connectionFactory);// 创建JSON序列化工具GenericJackson2JsonRedisSerializer jsonRedisSerializer = new GenericJackson2JsonRedisSerializer();//  设置Key的序列化redisTemplate.setKeySerializer(RedisSerializer.string());redisTemplate.setHashKeySerializer(RedisSerializer.string());//  设置Value的序列化redisTemplate.setValueSerializer(jsonRedisSerializer);redisTemplate.setHashValueSerializer(jsonRedisSerializer);//  返 回return  redisTemplate;}}
  1. 测试结果
    @Testvoid test002(){//  插入一条数据redisTemplate.opsForValue().set("user:20",new User("张三",28));//  读取一条数据Object name = redisTemplate.opsForValue().get("user:20");System.out.println("name="+name);}

在这里插入图片描述
这样也有缺点:为了在反序列化时知道对象的类型,JSON序列化器会将类的class类型写入json结果中,存入redis,会带来额外的开销。

四、StringRedisTemplate

解决:JSON序列化器会将类的class类型写入json结果中,存入redis,会带来额外的开销这一问题

4.1、解决方法

为了节省内存空间,我们并不会使用JSON序列化器来处理Value,而是统一使用String序列化器,要求只能存储String类型的key和value。当需要存储Java对象时,需要手动完成对象的序列化和反序列化。

Spring默认提供了一个StringRedisTemplate类,它的key和value的序列化方式默认就是String方式。省去了我们自义RedisTemplate的过程:

4.2、ObjectMapper介绍

是Java编程语言中常用的库,用于将Java对象与JSON(JavaScript对象表示法)数据之间进行转换。它是Jackson库的一部分,提供了一套用于在Java中处理JSON的数据处理工具。

ObjectMapper主要使用方法

// 将Java对象序列化为JSON字符串String jsonString = objectMapper.writeValueAsString(person);
// 将JSON字符串反序列化为Java对象Person deserializedPerson = objectMapper.readValue(jsonString, 需要待转的对象类.class);

4.3、StringRedisTemplate类

StringRedisTemplate类的使用:

@SpringBootTest
public class RedisString {@Autowiredprivate StringRedisTemplate stringRedisTemplate;//引入ObjectMapperJSON处理类private static final ObjectMapper objectMapper = new ObjectMapper();@Testvoid  testString() throws JsonProcessingException {User user = new User("李四", 14);// 1.存数据// 将User对象转换为Json数据String jsonString  = objectMapper.writeValueAsString(user);System.out.println(jsonString);  // {"username":"李四","age":14}stringRedisTemplate.opsForValue().set("name",jsonString);// 2.取数据String name = stringRedisTemplate.opsForValue().get("name");System.out.println(name);   // {"username":"李四","age":14}//  将JSON数据转为对象格式User user1 = objectMapper.readValue(name, User.class);System.out.println(user1);  //   User(username=李四, age=14)}
}

之前的问题得到了解决:
在这里插入图片描述

五、其它结构的使用

Hash结构的使用:使用基本没有太大差别,更多的是偏向Java代码的这种分格

代码:

  @Testvoid test002(){//  存数据stringRedisTemplate.opsForHash().put("user:23","name","小王");stringRedisTemplate.opsForHash().put("user:23","age","6");// 取一个字段Object name = stringRedisTemplate.opsForHash().get("user:23", "name");System.out.println(name);// 取所有的字段Map<Object, Object> objectMap = stringRedisTemplate.opsForHash().entries("user:23");System.out.println(objectMap);}

测试:

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

10.1网站编写(Tomcat和servlet基础)

一.Tomcat: 1.Tomcat是java写的,运行时需要依赖jre,所以要装jdk. 2.建议配置好环境变量. 3.默认端口号8080(业务端口)可能会被占用,建议改一下(本人改成了9999). 4.另一个默认端口是8005(管理端口). 二Servlet基础(编写一个hello world代码): 整体分为7个步骤,分别是创建…

linux安装mysql8.0

最近在云服务器上部署服务&#xff0c;需要在linux端安装mysql8以上的版本&#xff0c;出现一些问题&#xff0c;记录一下。 1.首先卸载以前mysql版本。 &#xff08;1&#xff09;停止mysql服务。 systemctl stop mysqld.service (2)删除对应程序与文件。 查看安装…

什么是机器学习?

所谓的机器学习就是让机器去学习&#xff0c; 在这里关键词是学习两个字 在我们传统的学习算法的过程中&#xff0c; 我们真正要做的事情其实是让机器去执行&#xff0c;也就是说设计一个算法&#xff0c; 去让机器具体的完成一个任务&#xff0c;而不是学习一个任务 最早的机器…

JumpServer开源堡垒机与爱可生云树数据库完成兼容性认证

近日&#xff0c;中国领先的开源软件提供商FIT2CLOUD飞致云宣布&#xff0c;JumpServer开源堡垒机已经完成与爱可生云树数据库软件的兼容性认证。经过双方联合测试&#xff0c;云树数据库软件&#xff08;简称&#xff1a;ActionDB&#xff09;V1.0与杭州飞致云信息科技有限公司…

雷达编程实战之静态杂波滤除与到达角估计

雷达中经过混频的中频信号常常混有直流分量等一系列硬件设计引入的固定频率杂波&#xff0c;我们称之位静态杂波&#xff0c;雷达信号处理需要把这些静态杂波滤除从而有效的提高信噪比&#xff0c;实现准确的目标检测功能。 目标的到达角估计作为常规车载雷达信号处理的末端&am…

针对敏感数据的安全转录服务

即便在新冠肺炎疫情期间&#xff0c;继续保持了最高级别的机密性 新冠肺炎疫情带来的各种限制向所有服务提供商提出了挑战&#xff0c;促使提供商们想方设法采取更富想象力的新方法来满足客户的需求。澳鹏采用了一种由两种方案组成的工作机制&#xff0c;服务于客户机密材料的…

解决Spring Boot 2.7.16 在服务器显示启动成功无法访问问题:从本地到服务器的部署坑

&#x1f337;&#x1f341; 博主猫头虎 带您 Go to New World.✨&#x1f341; &#x1f984; 博客首页——猫头虎的博客&#x1f390; &#x1f433;《面试题大全专栏》 文章图文并茂&#x1f995;生动形象&#x1f996;简单易学&#xff01;欢迎大家来踩踩~&#x1f33a; &a…

【100天精通Python】Day69:Python可视化_实战:导航定位中预测轨迹和实际轨迹的3D动画,示例+代码

目录 1. 预测的3D轨迹和实际轨迹的动画图&#xff0c;同时动态更新 2 真值轨迹设置为静态的&#xff0c;预测轨迹不断更新 3 网格的三维坐标系有旋转运动&#xff0c;以此全方位展示预测轨迹和真值轨迹之间的空间关系 1. 预测的3D轨迹和实际轨迹的动画图&#xff0c;同时动态更…

【Phoenix】phoenix实现每个Primarykey主键保留N版本数据,CDC数据记录为Changelog格式

一、背景&#xff1a; CDC数据中包含了&#xff0c;数据的变更过程。当CDC写入传统数据库最终每一个primary key下会保存一条数据。当然可以使用特殊手段保存多分记录但是显然造成了数据膨胀。 另外数据湖Hudi(0.13.1)是不支持保存所有Changelog其Compaction机制会清除所有旧版…

【操作系统笔记一】程序运行机制CPU指令集

内存地址 指针 / 引用 指针、引用本质上就是内存地址&#xff0c;有了内存地址就可以操作对应的内存数据了。 不同的数据类型 字节序 大端序&#xff08;Big Endian&#xff09;&#xff1a;字节顺序从低地址到高地址顺序存储的字节序小端序&#xff08;Little Endian&#…

【MySQL】 MySQL索引事务

文章目录 &#x1f6eb;索引&#x1f38d;索引的概念&#x1f333;索引的作用&#x1f384;索引的使用场景&#x1f340;索引的使用&#x1f4cc;查看索引&#x1f4cc;创建索引&#x1f332;删除索引 &#x1f334;索引保存的数据结构&#x1f388;B树&#x1f388;B树&#x…

10.5 串联型稳压电路(1)

稳压管稳压电路输出电流较小&#xff0c;输出电压不可调&#xff0c;不能满足很多场合下的应用。串联型稳压电路以稳压管稳压电路为基础&#xff0c;利用晶体管的电流放大作用&#xff0c;增大负载电流&#xff1b;在电路中引入深度电压负反馈使输出电压稳定&#xff1b;并且&a…

RabbitMQ快速入门——消费者

public class Consumer_HelloWorld {public static void main(String[] args) throws IOException, TimeoutException {//1.创建连接工厂ConnectionFactory factory new ConnectionFactory();//2.设置参数factory.setHost("172.16.98.133"); ip 默认值 localhostfac…

【论文写作】符号:矩阵、向量的乘法、内积、点积等

【论文写作】符号&#xff1a;矩阵、向量乘法、内积、点积等 文章目录 【论文写作】符号&#xff1a;矩阵、向量乘法、内积、点积等1. 矩阵乘法1.1 矩阵乘积1.2 矩阵哈德玛乘积1.3 矩阵克罗内克积 2. 向量乘法2.1 向量点积、内积2.2 向量Hadamard积2.3 向量外积2.4 向量叉积 1.…

预训练相关知识

1、上下文无关语义表示方式存在问题 语义不同的词具有相同的表示&#xff0c;&#xff08;apple 电子产品苹果/水果苹果&#xff09; 容易出现oov问题 2、神经语言编码器 2.1、序列模型 cnn/rnn等&#xff0c;捕获局部信息和序列依赖信息&#xff0c;无法捕获长距离依赖。易训…

罗德里格斯公式

1.点乘 A ⃗ ⋅ B ⃗ ∣ A ⃗ ∣ ∣ B ⃗ ∣ c o s ⟨ A ⃗ , B ⃗ ⟩ \vec{A} \cdot \vec{B} \left | \vec{A} \right | \left | \vec{B} \right | cos\left \langle \vec{A}, \vec{B} \right \rangle A ⋅B ​A ​ ​B ​cos⟨A ,B ⟩ 对应几何意义&#xff1a;向量 A ⃗…

STL-常用容器

string容器 string构造函数 string本质&#xff1a;类 string和char*区别&#xff1a; char* 是一个指针 string是一个类&#xff0c;类内部封装了char*&#xff0c;管理这个字符串&#xff0c;是一个char*型的容器。 特点&#xff1a; string类内部封装了很多成员方法 …

Android 12,调用系统库libft2.so 遇到的各种问题记录

问题前提,Android 12系统,vendor静态库中调用 libft2.so。(vendor静态库中调用libft2.so会简单点,没这么麻烦) 【问题1】 (native:vendor) can not link against libft2 (native:platform) 本地debug尝试修改: 为了本地环境debug调试方便,我找了个 mk文件,在里面添加了…

Centos安装显卡

1、安装基础环境 yum -y install epel-release yum -y install gcc kernel-devel kernel-headers 2.对应内核版本 yum info kernel-devel kernel-headers Cat /proc/version 3、yum安装版本不对应。则去官网手动下载 离线安装对应的rpm&#xff1a; https://pkgs.org/dow…

RPC框架学习

一、设计目标 RPC 框架的目标就是让远程服务调用更加简单、透明&#xff0c;RPC 框架负责屏蔽底层的传输方式&#xff08;TCP 或者 UDP&#xff09;、序列化方式&#xff08;XML/Json/ 二进制&#xff09;和通信细节。服务调用者可以像调用本地接口一样调用远程的服务提供者&a…