redis入门到精通系列(四):Jedis--使用java操作redis详解

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 如果不把数据库和后端语言联系起来,就起不到数据库应该要起到的作用。Java语言通过JDBC操作mysql,用Jedis操作redis。当然了,java操作redis的方式不止jedis一种,现在我们主要使用Jedis来操作redis。

点赞再看,养成习惯,听说微信搜《Java鱼仔》会让自己的技术更上一层楼


(一)前言


如果不把数据库和后端语言联系起来,就起不到数据库应该要起到的作用。Java语言通过JDBC操作mysql,用Jedis操作redis。当然了,java操作redis的方式不止jedis一种,现在我们主要使用Jedis来操作redis。


(二)第一个jedis项目


2.1 搭建项目


首先搭建一个空的maven项目,在pom.xml中导入redis的依赖,我同时还导入了junit的依赖用于测试。



<dependencies><dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>2.9.0</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency></dependencies>

2.2 创建测试类


在test包下创建测试类JedisTest,操作redis比操作mysql更简单,只需要以下三步:

1.连接jedis

2.操作jedis

3.关闭连接


publicclassJedisTest {
@TestpublicvoidtestJedis(){
//1.连接jedisJedisjedis=newJedis("127.0.0.1", 6379);
//2.操作jedisjedis.set("name","sdxb");
Stringname=jedis.get("name");
System.out.println(name);
//3.关闭连接jedis.close();
    }
}

其中第二步操作jedis中的操作和redis语法一致。查看结果:


网络异常,图片无法展示
|


(三)请求调用次数的限制案例代码模拟


在之前的一篇博客中我用redis模拟了请求调用次数限制案例,这一次就用java真实模拟后端逻辑,代码逻辑和之前所讲的redis操作逻辑一致。


publicclassService {
//请求模拟publicvoidcall(){
System.out.println("调用服务");
    }
//用户限制模拟,传入用户idpublicvoidlimitcall(Stringid){
Jedisjedis=newJedis("127.0.0.1", 6379);
Stringvalue=jedis.get("user"+id);
//第一步,查看该值是否存在try {
if (value==null){
//如果不存在,创建值,设置生命周期为20sjedis.setex("user"+id,20,Long.MAX_VALUE-10+"");
            }else{
//如果存在,则加1,直到超过最大值抛出异常jedis.incr("user"+id);
call();
            }
        }catch (JedisDataExceptione){
//超过最大值(即每20s访问超过10次),执行异常System.out.println("达到请求上限,稍后再试");
return;
        }finally {
jedis.close();
        }
    }
}
//多线程一直调用服务classMyThreadextendsThread{
Serviceservice=newService();
@Overridepublicvoidrun() {
while (true){
service.limitcall("用户A");
try {
Thread.sleep(1000L);
            } catch (InterruptedExceptione) {
e.printStackTrace();
            }
        }
    }
publicstaticvoidmain(String[] args) {
MyThreadmyThread=newMyThread();
myThread.run();
    }
}

查看结果,当20秒内调用服务达到10次时,再调用就会执行异常


网络异常,图片无法展示
|


(四)搭建一个Jedis工具类


如果每一次要使用Jedis都生成连接一次Jedis对象,就显得很麻烦,因此有必要写一个工具类方便重复调用。工具类的编写不难,通过Jedis自带的线程池调用线程就行。


publicclassJedisUtil {
privatestaticJedisPooljedisPool=null;
static {
//配置线程池JedisPoolConfigconfig=newJedisPoolConfig();
//设置最大空闲等待数config.setMaxIdle(10);
//设置最大连接数config.setMaxTotal(30);
jedisPool=newJedisPool(config,"127.0.0.1",6379);
    }
//通过该方法获取jedis对象publicstaticJedisgetJedis(){
returnjedisPool.getResource();
    }
}


在使用时将我们之前通过Jedis对象调用的方式换成工具类调用即可,修改上面案例的第八行:


// Jedis jedis = new Jedis("127.0.0.1", 6379);Jedisjedis=JedisUtil.getJedis();


还有一个小问题,如果把配置的具体信息都写在程序内部,如果要修改就需要重新启动整个项目,所以可以将配置信息写到配置文件中。在resource文件下新建jedis.properties


redis.host=127.0.0.1redis.port=6379redis.maxidle=10redis.maxtotal=30


修改工具类


publicclassJedisUtil {
privatestaticJedisPooljedisPool=null;
static {
//通过配置文件修改参数ResourceBundlerb=ResourceBundle.getBundle("jedis");
Stringhost=rb.getString("redis.host");
intport=Integer.parseInt(rb.getString("redis.port"));
intmaxidle=Integer.parseInt(rb.getString("redis.maxidle"));
intmaxtotal=Integer.parseInt(rb.getString("redis.maxtotal"));
//配置线程池JedisPoolConfigconfig=newJedisPoolConfig();
//设置最大空闲等待数config.setMaxIdle(maxidle);
//设置最大连接数config.setMaxTotal(maxtotal);
jedisPool=newJedisPool(config,host,port);
    }
//通过该方法获取jedis对象publicstaticJedisgetJedis(){
returnjedisPool.getResource();
    }
}


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
1月前
|
存储 安全 Java
从入门到精通:Java Map全攻略,一篇文章就够了!
【10月更文挑战第17天】本文详细介绍了Java编程中Map的使用,涵盖Map的基本概念、创建、访问与修改、遍历方法、常用实现类(如HashMap、TreeMap、LinkedHashMap)及其特点,以及Map在多线程环境下的并发处理和性能优化技巧,适合初学者和进阶者学习。
48 3
|
10天前
|
监控 安全 Java
Java中的多线程编程:从入门到实践####
本文将深入浅出地探讨Java多线程编程的核心概念、应用场景及实践技巧。不同于传统的摘要形式,本文将以一个简短的代码示例作为开篇,直接展示多线程的魅力,随后再详细解析其背后的原理与实现方式,旨在帮助读者快速理解并掌握Java多线程编程的基本技能。 ```java // 简单的多线程示例:创建两个线程,分别打印不同的消息 public class SimpleMultithreading { public static void main(String[] args) { Thread thread1 = new Thread(() -> System.out.prin
|
14天前
|
存储 消息中间件 NoSQL
使用Java操作Redis数据类型的详解指南
通过使用Jedis库,可以在Java中方便地操作Redis的各种数据类型。本文详细介绍了字符串、哈希、列表、集合和有序集合的基本操作及其对应的Java实现。这些示例展示了如何使用Java与Redis进行交互,为开发高效的Redis客户端应用程序提供了基础。希望本文的指南能帮助您更好地理解和使用Redis,提升应用程序的性能和可靠性。
30 1
|
16天前
|
Java 大数据 API
14天Java基础学习——第1天:Java入门和环境搭建
本文介绍了Java的基础知识,包括Java的简介、历史和应用领域。详细讲解了如何安装JDK并配置环境变量,以及如何使用IntelliJ IDEA创建和运行Java项目。通过示例代码“HelloWorld.java”,展示了从编写到运行的全过程。适合初学者快速入门Java编程。
|
22天前
|
存储 安全 Java
🌟Java零基础-反序列化:从入门到精通
【10月更文挑战第21天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
63 5
|
20天前
|
安全 Java 调度
Java中的多线程编程入门
【10月更文挑战第29天】在Java的世界中,多线程就像是一场精心编排的交响乐。每个线程都是乐团中的一个乐手,他们各自演奏着自己的部分,却又和谐地共同完成整场演出。本文将带你走进Java多线程的世界,让你从零基础到能够编写基本的多线程程序。
32 1
|
26天前
|
Java 数据处理 开发者
Java多线程编程的艺术:从入门到精通####
【10月更文挑战第21天】 本文将深入探讨Java多线程编程的核心概念,通过生动实例和实用技巧,引导读者从基础认知迈向高效并发编程的殿堂。我们将一起揭开线程管理的神秘面纱,掌握同步机制的精髓,并学习如何在实际项目中灵活运用这些知识,以提升应用性能与响应速度。 ####
44 3
|
28天前
|
Java
Java中的多线程编程:从入门到精通
本文将带你深入了解Java中的多线程编程。我们将从基础概念开始,逐步深入探讨线程的创建、启动、同步和通信等关键知识点。通过阅读本文,你将能够掌握Java多线程编程的基本技能,为进一步学习和应用打下坚实的基础。
|
29天前
|
存储 安全 Java
从入门到精通:Java Map全攻略,一篇文章就够了!
【10月更文挑战第19天】本文介绍了Java编程中重要的数据结构——Map,通过问答形式讲解了Map的基本概念、创建、访问与修改、遍历方法、常用实现类(如HashMap、TreeMap、LinkedHashMap)及其特点,以及Map在多线程环境下的使用和性能优化技巧,适合初学者和进阶者学习。
44 4
|
28天前
|
Java
[Java]Socket套接字(网络编程入门)
本文介绍了基于Java Socket实现的一对一和多对多聊天模式。一对一模式通过Server和Client类实现简单的消息收发;多对多模式则通过Server类维护客户端集合,并使用多线程实现实时消息广播。文章旨在帮助读者理解Socket的基本原理和应用。
23 1
下一篇
无影云桌面