【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中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

Redis 热 key 和大 key 问题小结

《Redis热key和大key问题小结》:本文主要介绍Redis热key和大key问题小结,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、什么是 Redis 热 key?热 key(Hot Key)定义: 热 key 常见表现:热 key 的风险:二、

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Redis Pipeline(管道) 详解

《RedisPipeline(管道)详解》Pipeline管道是Redis提供的一种批量执行命令的机制,通过将多个命令一次性发送到服务器并统一接收响应,减少网络往返次数(RTT),显著提升执行效率... 目录Redis Pipeline 详解1. Pipeline 的核心概念2. 工作原理与性能提升3. 核

redis过期key的删除策略介绍

《redis过期key的删除策略介绍》:本文主要介绍redis过期key的删除策略,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录第一种策略:被动删除第二种策略:定期删除第三种策略:强制删除关于big key的清理UNLINK命令FLUSHALL/FLUSHDB命

Redis消息队列实现异步秒杀功能

《Redis消息队列实现异步秒杀功能》在高并发场景下,为了提高秒杀业务的性能,可将部分工作交给Redis处理,并通过异步方式执行,Redis提供了多种数据结构来实现消息队列,总结三种,本文详细介绍Re... 目录1 Redis消息队列1.1 List 结构1.2 Pub/Sub 模式1.3 Stream 结

SpringBoot中配置Redis连接池的完整指南

《SpringBoot中配置Redis连接池的完整指南》这篇文章主要为大家详细介绍了SpringBoot中配置Redis连接池的完整指南,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以... 目录一、添加依赖二、配置 Redis 连接池三、测试 Redis 操作四、完整示例代码(一)pom.

Redis在windows环境下如何启动

《Redis在windows环境下如何启动》:本文主要介绍Redis在windows环境下如何启动的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Redis在Windows环境下启动1.在redis的安装目录下2.输入·redis-server.exe

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析