Redis基础篇:Redis的Java客户端

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: Redis基础篇:Redis的Java客户端


第一章:客户端对比

Redis官网中提供了各种语言的客户端,供我们使用。

我们关注的一定是Java客户端,然而Java的客户端也有N多个,标注*的是推荐使用的。

一:Jedis

Jedis当中的命令命名与redis实际命令一致,学习成本低。但是Jedis实例是线程不安全的,创建一个Jedis实例,多线程需要基于连接池来使用。

二:lettuce

Lettuce是基于Netty实现的,支持同步、异步和响应式变成方式,并且是线程安全的。支持Redis的哨兵模式、集群模式和普通模式。

Spring默认兼容

三:Redisson

Redisson是一个基于Redis实现的分布式、可伸缩的、Java数据结构集合。包含了诸如Map、Queue、Lock、Semaphore、AtomicLong等强大功能。

Spring Data Redis底层兼容了 jedis和lettuce,底层可以无缝切换,这样我们使用即可。Redisson在我们使用分布式锁的时候用的比较多。

第二章 Jedis快速入门

一:添加依赖

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

二:建立链接

private Jedis jedis;
@BeforeEach
void setUp(){
    //建立连接
    jedis=new Jedis("192.168.150.101",6379);//redisip地址。
    //设置密码
    jedis.auth(123321);
    //选择库
    jedis.select(0);//默认就是第一个库
}

三:测试String

@Test
void teststring(){
  //插入数据,方法名称就是r©dis命令名称,非常简单
  String result=jedis.set("name","张三");
  System.out.println("result ="result);
  //获取效据
  String name jedis.get("name");
  System.out.println("name ="name);
}

四:测试哈希

@Test
void testHash(){
//插入hash数据
jedis.hset("user:1","name","ack");
jedis.hset("user:1","age","21");
//获取
Map<String,String>map jedis.hgetAll("1");
System.out.println(map);

五:释放资源

4.释放资源
@AfterEach
void tearDown(){
  //释放瓷源
  if (jedis !null){
  jedis.close();
}

第三章:Jedis连接池

Jedis本身是线程不安全的。并发条件下通过Jedis操作Redis会出现线程安全问题。

同时,频繁的创建和销毁链接都会有性能损耗,因此我们推荐大家使用Jedis连接池代替Jedis直连的方式。

public class JedisConnectionFactory {
  private static final JedisPool jedisPool;
  static {
    //连接池配置对象。
    JedisPoolConfig jedisPoolConfig =new JedisPoolConfig();
    //最大连接
    jedisPoolConfig.setMaxTotal(8);//最多允许你创建多少个连接
    //最大空连接
    jedisPoolConfig. setMaxIdle(8);//最大空闲连接,没有人使用这个,最多有8个连接。
    //最小空闲连接
    jedisPoolConfig.setMinIdle0);//最小空闲连接,超过一段时间之后一直没有人访问,这些连接被释放。
    //设置最长等侍时间,ms
    jedisPoolConfig. setMaxWaitMillis(200);//连接池当中没有连接的时候,是否要等待,默认是-1,也就是一直等待,我们默认等待200ms,超过这个时间,就该报错了。
    //连接池对象
    jedisPool = new JedisPooljedisPoolConfig("192.168.150.101“,6379,
    1000,"123321);//ip+port+超时时间+密码;
  }
} 
//获取Jedis对象。这是一个静态方法。
public static Jedis getJedis(){
  return jedisPool.getResource();
}

通过这个静态方法,大家都从这个池子当中去拿取Jedis对象,基于池化思想,避免了jedis对象的频繁的创建和销毁,节省了计算机资源。

private Jedis jedis;
@BeforeEach
void setUp(){
    //建立连接
    jedis=JedisConnectionFactory .getgetJedis();
    //设置密码
    jedis.auth(123321);
    //选择库
    jedis.select(0);//默认就是第一个库
}

当我们使用池化技术的时候redis.close()就变成了这:

相关实践学习
基于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
相关文章
|
12天前
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
73 26
|
1月前
|
存储 消息中间件 NoSQL
使用Java操作Redis数据类型的详解指南
通过使用Jedis库,可以在Java中方便地操作Redis的各种数据类型。本文详细介绍了字符串、哈希、列表、集合和有序集合的基本操作及其对应的Java实现。这些示例展示了如何使用Java与Redis进行交互,为开发高效的Redis客户端应用程序提供了基础。希望本文的指南能帮助您更好地理解和使用Redis,提升应用程序的性能和可靠性。
38 1
|
1月前
|
存储 Java API
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
51 4
|
2月前
|
NoSQL 网络协议 算法
Redis 客户端连接
10月更文挑战第21天
38 1
|
2月前
|
缓存 NoSQL Java
Java中redis面试题
Java中redis面试题
51 1
|
1月前
|
存储 NoSQL Java
Java 使用 Redis
10月更文挑战第22天
44 0
|
2月前
|
NoSQL Java API
Java操作redis
Java操作redis
|
7月前
|
NoSQL Java Redis
用java写个redis工具类
用java写个redis工具类
145 0
|
NoSQL Java Redis
java Redis工具类
java Redis工具类
1018 2
|
7天前
|
安全 Java API
java如何请求接口然后终止某个线程
通过本文的介绍,您应该能够理解如何在Java中请求接口并根据返回结果终止某个线程。合理使用标志位或 `interrupt`方法可以确保线程的安全终止,而处理好网络请求中的各种异常情况,可以提高程序的稳定性和可靠性。
37 6
下一篇
DataWorks