【Redis学习笔记04】Jedis客户端(上)

2024-06-10 03:36

本文主要是介绍【Redis学习笔记04】Jedis客户端(上),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Java客户端操作Redis

Java生态丰富,自定义的客户端非常多,常见的有Jedis、Lettuce、以及Spring整合后的RedisTemplate,但是对于初学者而言,从Jedis开始入门学习是非常容易上手的,因为Jedis中的API与原生Redis命令高度一致。

1. 引入Jedis依赖

此处引入如下依赖:

  • Jedis:Java操作Redis客户端
  • Junit:方便编写单元测试
<!-- https://mvnrepository.com/artifact/redis.clients/jedis -->
<dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>4.4.3</version>
</dependency>
<!-- https://mvnrepository.com/artifact/junit/junit -->
<dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope>
</dependency>

2. 配置Xshell端口转发

  1. 操作步骤:1. 打开Xshell点击属性 => 2. 配置SSH隧道 => 3. 配置如下端口转发内容

image.png

  1. 打开windows cmd程序输入:netstat -ano | findstr 8888如果观察如下

image.png

  1. 确保redis.conf配置中设置protect-mode为no以及bind为0.0.0.0

3. 编写Demo

使用Jedis的步骤如下:

  1. 创建JedisPool连接池对象(配置redis服务器所在IP地址+端口号)
  2. 从JedisPool连接池中取出连接对象,并操作其中提供的API方法
  3. 解析响应内容
/*** 测试Redis连通性* @author 米饭好好吃*/
@Test
public void testPing() {// 1. 创建JedisPoolJedisPool pool = new JedisPool("tcp://127.0.0.1:8888");// 2. 获取连接对象try(Jedis jedis = pool.getResource();) {// 设置密码(如果有)jedis.auth("xxxxxx");// 3. 调用API-pingString pong = jedis.ping();// 4. 解析响应结果System.out.println(pong);}
}

4. 测试通用命令

  1. 测试SET、GET命令:
    :::success
    注意:此处GET、SET命令是针对string类型的,此处测试通用命令需要借助SET、GET命令
    :::
/*** 测试通用命令* @author 米饭好好吃*/
public class TestCommon {// redis连接池对象private JedisPool pool;@Beforepublic void init() {pool = new JedisPool("tcp://127.0.0.1:6379");}/*** 测试SET、GET命令*/@Testpublic void testGETAndSET() {// 1. 获取连接对象try(Jedis jedis = pool.getResource();) {// 2. 配置密码(如果有的话)jedis.auth("xxxxxx");// 3. 清空数据库jedis.flushDB();// 4. 测试SET命令jedis.set("k1", "hello");// 5. 测试GET命令String resp = jedis.get("k1");System.out.println("k1: " + resp);// 6. 测试SET 选项NX命令SetParams params = new SetParams();params.nx(); // 不存在才新增jedis.set("k1", "222", params);resp = jedis.get("k1");System.out.println("k1: " + resp);}}
}
  1. 测试EXISTS命令:

/*** 测试EXISTS命令* @author 米饭好好吃*/
@Test
public void testEXISTS() {// 1. 获取到redis连接对象try(Jedis jedis = pool.getResource();) {// 2. 配置密码(如果有的话)jedis.auth("xxxxxx");// 3. 清空数据库jedis.flushDB();// 4. 测试EXISTS命令jedis.set("k1", "111");boolean exists = jedis.exists("k1");System.out.println("k1: " + exists);jedis.del("k1");exists = jedis.exists("k1");System.out.println("k1: " + exists);}
}
  1. 测试DEL命令:
/*** 测试DEL命令* @author 米饭好好吃*/
@Test
public void testDEL() {// 1. 创建redis连接对象try(Jedis jedis = pool.getResource();) {// 2. 配置密码(如果有的话)jedis.auth("xxxxxx");// 3. 清空数据库jedis.flushDB();// 4. 测试del命令jedis.set("k1", "111");jedis.set("k2", "222");jedis.set("k3", "333");long delCount = jedis.del("k1", "k2", "k3");System.out.println("delCount: " + delCount);String resp = jedis.get("k1");System.out.println("k1: " + resp);}
}

注意:DEL命令中参数列表为可边长参数,可以同时删除多个key,并且返回值为删除成功的个数,这与命令行中DEL命令一致

  1. 测试KEYS命令:
/*** 测试KEYS命令* @author 米饭好好吃*/
@Test
public void testKEYS() {// 1. 获取redis连接对象try(Jedis jedis = pool.getResource();) {// 2. 配置密码(如果有的话)jedis.auth("xxxxxx");// 3. 清空数据库jedis.flushDB();// 4. 测试KEYS命令jedis.set("k1", "111");jedis.set("k2", "222");jedis.set("k3", "333");Set<String> keys = jedis.keys("*");System.out.println("keys: " + keys);}
}

注意:KEYS命令返回的是一个Java当中的Set类型,这是因为redis中的key都是不允许重复且对于顺序没有要求的,KEYS方法可以传递一个pattern参数,即KEYS命令后紧跟的匹配模式

  1. 测试EXPIRE、TTL命令:
/*** 测试EXPIRE命令* @author 米饭好好吃*/
@Test
public void testEXPIRE() {// 1. 获取redis连接对象try(Jedis jedis = pool.getResource();) {// 2. 设置密码(如果有的话)jedis.auth("xxxxxx");// 3. 清空数据库jedis.flushDB();// 4. 测试expire、ttljedis.set("k1", "111");jedis.expire("k1", 10);long ttl = jedis.ttl("k1");System.out.println("ttl: " + ttl);}
}
  1. 测试TYPE命令:
/*** 测试TYPE命令* @author 米饭好好吃*/
@Test
public void testTYPE() {// 1. 获取redis连接对象try(Jedis jedis = pool.getResource();) {// 2. 设置密码(如果有的话)jedis.auth("xxxxxx");// 3. 清空数据库jedis.flushDB();// 4. 测试type命令jedis.hset("k1", "f1", "v1");jedis.lpush("k2", "11", "22", "33");jedis.sadd("k3", "abc");System.out.println("k1: " + jedis.type("k1"));System.out.println("k2: " + jedis.type("k2"));System.out.println("k3: " + jedis.type("k3"));}
}

这篇关于【Redis学习笔记04】Jedis客户端(上)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1047106

相关文章

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

redis-sentinel基础概念及部署流程

《redis-sentinel基础概念及部署流程》RedisSentinel是Redis的高可用解决方案,通过监控主从节点、自动故障转移、通知机制及配置提供,实现集群故障恢复与服务持续可用,核心组件包... 目录一. 引言二. 核心功能三. 核心组件四. 故障转移流程五. 服务部署六. sentinel部署

基于Redis自动过期的流处理暂停机制

《基于Redis自动过期的流处理暂停机制》基于Redis自动过期的流处理暂停机制是一种高效、可靠且易于实现的解决方案,防止延时过大的数据影响实时处理自动恢复处理,以避免积压的数据影响实时性,下面就来详... 目录核心思路代码实现1. 初始化Redis连接和键前缀2. 接收数据时检查暂停状态3. 检测到延时过

Redis实现分布式锁全过程

《Redis实现分布式锁全过程》文章介绍Redis实现分布式锁的方法,包括使用SETNX和EXPIRE命令确保互斥性与防死锁,Redisson客户端提供的便捷接口,以及Redlock算法通过多节点共识... 目录Redis实现分布式锁1. 分布式锁的基本原理2. 使用 Redis 实现分布式锁2.1 获取锁

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

redis数据结构之String详解

《redis数据结构之String详解》Redis以String为基础类型,因C字符串效率低、非二进制安全等问题,采用SDS动态字符串实现高效存储,通过RedisObject封装,支持多种编码方式(如... 目录一、为什么Redis选String作为基础类型?二、SDS底层数据结构三、RedisObject

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.