Redis之Java客户端

本文涉及的产品
云原生内存数据库 Tair,内存型 2GB
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Redis 版,经济版 1GB 1个月
简介: 在Redis官网中提供了各种语言的客户端

在Redis官网中提供了各种语言的客户端,地址:https://redis.io/clients,不过我是学Java的,那这里就给大家介绍javad的客户端。

点击图中标红的Java点击。

这里就大家简单介绍一下名列前茅的三种客户端。

1、Jedis

优点:以命令作为方法名称,学习成本低,简单实用。

缺点:但是实例是线程不安全的,多线程环境下需要基于连接池来使用

2、lettuce

是基于Netty实现的,支持同步、异步和响应式编程方式,并且是线程安全的。

支持Redis的哨兵模式、集群模式和管道模式。

3、Redisson

是一个基于Redis实现的分布式、可伸缩的Java数据结构集合。

包含了诸如Map、Queue、Lock、 Semaphore、AtomicLong等强大功能

以上是3种客户端的简单介绍,一般我们使用Redis做一些简单的业务逻辑,使用Jedis和lettuce相对会方便一些。

一个一个去学就优点费劲,所以我们会使用到spring,spring最擅长的东西就是整合了,Spring Data Redis 就整合了这两种方式。

不过可能有很多企业并没有使用spring 这套API ,而是使用Jedis,简单嘛,所以本篇博客也会简单介绍一下jedis 和 Jedis 的简单使用。

1、Jedis

Jedis的官网地址: https://github.com/redis/jedis,我们先来个快速入门:

我们先简单建一个MAVEN 项目,然后在pom.xml 引入依赖。

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

最好再引入一个junit 单元测试,我就基于单元测试给大家演示。

引入完依赖,我们就开始下一步,建立连接。

建立连接之后,就可以测试方法啦,比如Reids Stirng类型的 SET

最后别忘记了关闭连接。

运行结果:

除了控制台打印的,我们还可以使用 Redis 的可视化工具看看。

其他方法也是如此,大家可以去试试。

1.1 Jedis 连接池

前面也介绍了Jedis 的线程是不安全的,并且频繁的创建和销毁连接会有性能损耗,因此我们推荐大家使用Jedis连接池代替Jedis的直连方式。这里就直接创建一个工厂类。

package com.jie.introduction;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
import redis.clients.jedis.JedisSentinelPool;

/**
 * @description:jedis连接池
 * @author: jie
 * @time: 2022/4/27 21:38
 */
public class JedisConnectionFactory {

    private static final JedisPool JEDIS_POOL;

    static {
        //配置连接池
        JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
        //设置连接数
        jedisPoolConfig.setMaxTotal(8);
        //设置最大空闲连接
        jedisPoolConfig.setMaxIdle(8);
        // 设置最小连接
        jedisPoolConfig.setMinIdle(0);
        //等待时长 当连接池没有可用的时候 等不等待 等多久
        jedisPoolConfig.setMaxWaitMillis(1000);

        //创建连接池对象 还是老样子,没有密码就不设置密码。
        JEDIS_POOL = new JedisPool(jedisPoolConfig,"127.0.0.1",6379,1000);

    }

    public static Jedis getJedis(){
        return JEDIS_POOL.getResource();
    }

}

创建完之后我们再去测试测试。

2、Spring Data Redis

SpringData是Spring中数据操作的模块,包含对各种数据库的集成,其中对Redis的集成模块就叫做SpringDataRedis,官网地址:https://spring.io/projects/spring-data-redis

特点:

  • 提供了对不同Redis客户端的整合(Lettuce和Jedis)
  • 提供了RedisTemplate统一API来操作Redis
  • 支持Redis的发布订阅模型
  • 支持Redis哨兵和Redis集群
  • 支持基于Lettuce的响应式编程
  • 支持基于JDK、JSON、字符串、Spring对象的数据序列化及反序列化
  • 支持基于Redis的JDKCollection实现

SpringDataRedis中提供了RedisTemplate工具类,其中封装了各种对Redis的操作。并且将不同数据类型的操作API封装到了不同的类型中:

API 返回值类型 说明
redisTemplate.opsForValue() ValueOperations 操作String类型数据
redisTemplate.opsForHash() HashOperations 操作Hash类型数据
redisTemplate.opsForList() ListOperations 操作List类型数据
redisTemplate.opsForSet() SetOperations 操作Set类型数据
redisTemplate.opsForZSet() ZSetOperations 操作SortedSet类型数据
redisTemplate 通用的命令

2.1 基于SpringBoot快速入门

SpringBoot已经提供了对SpringDataRedis的支持,使用非常简单:

我们创建一个Spring Boot 项目

勾选上面的选项后会自动引入 spring date Redis 依赖,然后我们再引入一个连接池依赖。

 <!--连接池依赖-->
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-pool2</artifactId>
        </dependency>

依赖引入完毕后,我们再去编写yml 配置文件。

server:
  port: 2022
spring:
  redis:
    host: 127.0.0.1 # ip 地址
    port: 6379 # 端口
    password:  #密码 没有就输入
    lettuce:
      pool:
        max-active: 8 # 最大连接
        max-idle: 8 # 最大空闲连接
        min-idle: 0 # 最小连接
        max-wait: 100ms #等待时长

springDataRedis 默认支持lettuce,如果我们要使用jedis,就要去导入相关依赖。

就可以去进行相关测试啦。

这里我们也看到打印成功。

2.2 SpringDataRedis的序列化方式

我现在打开Redis自带的命令行客户端,查看一下我们刚刚插入进去的数据。

发现居然没有变化?这时候查询所有键。

我的博客名称怎么会变成这样?

这是因为RedisTemplate可以接收任意Object作为值写入Redis,只不过写入前会把Object序列化为字节形式,默认是采用JDK序列化,所以得到的结果是这样的。

这种方式有以下缺点:

  • 可读性差
  • 内存占用较大

但是,我们可以自定义RedisTemplate的序列化方式,代码如下。

package com.jie.introduction.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializer;

/**
 * @description:修改序列化方式
 * @author: jie
 * @time: 2022/4/27 22:56
 */
@Configuration
public class RedisConfig {

    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory connectionFactory){
        // 创建RedisTemplate对象
        RedisTemplate<String, Object> template = new RedisTemplate<>();
        // 设置连接工厂
        template.setConnectionFactory(connectionFactory);
        // 创建JSON序列化工具
        GenericJackson2JsonRedisSerializer jsonRedisSerializer = new GenericJackson2JsonRedisSerializer();
        // 设置Key的序列化
        template.setKeySerializer(RedisSerializer.string());
        template.setHashKeySerializer(RedisSerializer.string());
        // 设置Value的序列化
        template.setValueSerializer(jsonRedisSerializer);
        template.setHashValueSerializer(jsonRedisSerializer);
        // 返回
        return template;
    }
}

这里大概还要引入一个依赖,因为我们用到了一个json转换。注:springmvc自带。

 <!--Jackson依赖-->
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
        </dependency>

配置好之后,我们就可以再去发送一次请求,去可视化工具看看效果如何。

好了,今天的Redis之JAVA客户端就介绍到这里,后续会持续再更新,记得点个关注不迷路,我们下次再见!

相关实践学习
基于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
相关文章
|
7天前
|
缓存 监控 Java
Java Socket编程最佳实践:优化客户端-服务器通信性能
【6月更文挑战第21天】Java Socket编程优化涉及识别性能瓶颈,如网络延迟和CPU计算。使用非阻塞I/O(NIO)和多路复用技术提升并发处理能力,减少线程上下文切换。缓存利用可减少I/O操作,异步I/O(AIO)进一步提高效率。持续监控系统性能是关键。通过实践这些策略,开发者能构建高效稳定的通信系统。
|
7天前
|
Java 应用服务中间件 开发者
【实战指南】Java Socket编程:构建高效的客户端-服务器通信
【6月更文挑战第21天】Java Socket编程用于构建客户端-服务器通信。`Socket`和`ServerSocket`类分别处理两端的连接。实战案例展示了一个简单的聊天应用,服务器监听端口,接收客户端连接,并使用多线程处理每个客户端消息。客户端连接服务器,发送并接收消息。了解这些基础,加上错误处理和优化,能帮你开始构建高效网络应用。
|
7天前
|
IDE Java 开发工具
从零开始学Java Socket编程:客户端与服务器通信实战
【6月更文挑战第21天】Java Socket编程教程带你从零开始构建简单的客户端-服务器通信。安装JDK后,在命令行分别运行`SimpleServer`和`SimpleClient`。服务器监听端口,接收并回显客户端消息;客户端连接服务器,发送“Hello, Server!”并显示服务器响应。这是网络通信基础,为更复杂的网络应用打下基础。开始你的Socket编程之旅吧!
|
7天前
|
Java
Java Socket编程与多线程:提升客户端-服务器通信的并发性能
【6月更文挑战第21天】Java网络编程中,Socket结合多线程提升并发性能,服务器对每个客户端连接启动新线程处理,如示例所示,实现每个客户端的独立操作。多线程利用多核处理器能力,避免串行等待,提升响应速度。防止死锁需减少共享资源,统一锁定顺序,使用超时和重试策略。使用synchronized、ReentrantLock等维持数据一致性。多线程带来性能提升的同时,也伴随复杂性和挑战。
|
7天前
|
安全 Java 网络安全
Java Socket编程教程:构建安全可靠的客户端-服务器通信
【6月更文挑战第21天】构建安全的Java Socket通信涉及SSL/TLS加密、异常处理和重连策略。示例中,`SecureServer`使用SSLServerSocketFactory创建加密连接,而`ReliableClient`展示异常捕获与自动重连。理解安全意识,如防数据截获和中间人攻击,是首要步骤。通过良好的编程实践,确保网络应用在复杂环境中稳定且安全。
|
7天前
|
Java 数据安全/隐私保护
深入剖析:Java Socket编程原理及客户端-服务器通信机制
【6月更文挑战第21天】Java Socket编程用于构建网络通信,如在线聊天室。服务器通过`ServerSocket`监听,接收客户端`Socket`连接请求。客户端使用`Socket`连接服务器,双方通过`PrintWriter`和`BufferedReader`交换数据。案例展示了服务器如何处理每个新连接并广播消息,以及客户端如何发送和接收消息。此基础为理解更复杂的网络应用奠定了基础。
|
20小时前
|
NoSQL Java Redis
java架构之路-(Redis专题)SpringBoot连接Redis超简单
java架构之路-(Redis专题)SpringBoot连接Redis超简单
|
5天前
|
Java Android开发
Java Socket编程示例:服务器开启在8080端口监听,接收客户端连接并打印消息。
【6月更文挑战第23天】 Java Socket编程示例:服务器开启在8080端口监听,接收客户端连接并打印消息。客户端连接服务器,发送&quot;Hello, Server!&quot;后关闭。注意Android中需避免主线程进行网络操作。
31 4
|
8天前
|
NoSQL Java Redis
如何在 Java 中操作这些 Redis 数据结构的基本方法
如何在 Java 中操作这些 Redis 数据结构的基本方法
11 2
|
1天前
|
数据采集 Java API
Java HTTP客户端工具的演变之路
Java HTTP客户端工具的演变之路
7 0