Redis基础篇:Redis的Java客户端

本文涉及的产品
云数据库 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
相关文章
|
1天前
|
NoSQL Java Redis
如何在redis中设置文件夹名java - 蓝易云
在这个例子中,"folder:subfolder:key"就像一个文件夹路径,并且键的值被设置为"value"。然后,我们使用相同的键来获取并打印值。最后,记得关闭Jedis连接。
15 0
|
4天前
|
NoSQL 算法 Java
【redis源码学习】持久化机制,java程序员面试算法宝典pdf
【redis源码学习】持久化机制,java程序员面试算法宝典pdf
|
6天前
|
NoSQL Java Redis
在Java中操作Redis
在Java中操作Redis
13 0
|
6天前
|
JSON NoSQL Java
深入浅出Redis(十三):SpringBoot整合Redis客户端
深入浅出Redis(十三):SpringBoot整合Redis客户端
|
6天前
|
网络协议 Dubbo Java
【网络编程】理解客户端和服务器并使用Java提供的api实现回显服务器
【网络编程】理解客户端和服务器并使用Java提供的api实现回显服务器
11 0
|
6天前
|
存储 NoSQL 安全
java 中通过 Lettuce 来操作 Redis
java 中通过 Lettuce 来操作 Redis
java 中通过 Lettuce 来操作 Redis
|
6天前
|
Java
JavaFX库用于在Java中绘制K线图,适合构建富客户端应用。
JavaFX库用于在Java中绘制K线图,适合构建富客户端应用。以下是一个简单的K线图绘制示例:创建OHLCChart,设置标题和坐标轴,创建数据集并添加数据点,最后显示在Scene中。要定制图表外观,可利用JavaFX的丰富参数和方法。查阅JavaFX文档以获取更多细节。
28 3
|
6天前
|
JSON NoSQL Java
【Redis】2、Redis 的 Java 客户端(Jedis 和 SpringDataRedis)
【Redis】2、Redis 的 Java 客户端(Jedis 和 SpringDataRedis)
52 0
|
6天前
|
JSON NoSQL Java
⑩【Redis Java客户端】:Jedis、SpringDataRedis、StringRedisTemplate
⑩【Redis Java客户端】:Jedis、SpringDataRedis、StringRedisTemplate
33 0