Jedis学习笔记

文章目录

一、Jedis简介

Jedis是Redis的Java客户端,以其高性能和易用性著称,支持多种数据类型及事务、管道、连接池等功能。它并非线程安全,多线程环境下需通过连接池使用。

二、Jedis依赖配置

Maven依赖

xml 复制代码
<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>5.2.0</version>
</dependency>

Gradle依赖

groovy 复制代码
implementation 'redis.clients:jedis:5.2.0'

三、Jedis连接方式

单机连接

java 复制代码
Jedis jedis = new Jedis("localhost", 6379);

连接池配置

java 复制代码
JedisPool pool = new JedisPool("localhost", 6379);
try (Jedis jedis = pool.getResource()) {
    jedis.set("key", "value");
}

JedisPooled简化操作

java 复制代码
JedisPooled jedis = new JedisPooled("localhost", 6379);
jedis.set("key", "value");

集群连接

java 复制代码
Set<HostAndPort> nodes = new HashSet<>();
nodes.add(new HostAndPort("127.0.0.1", 7379));
nodes.add(new HostAndPort("127.0.0.1", 7380));
JedisCluster jedis = new JedisCluster(nodes);
jedis.set("key", "value");

四、Jedis基本操作

字符串操作

java 复制代码
jedis.set("name", "Jedis");
String value = jedis.get("name");

列表操作

java 复制代码
jedis.lpush("languages", "Java", "Python", "C++");
List<String> languages = jedis.lrange("languages", 0, -1);

哈希操作

java 复制代码
jedis.hset("user:1", "name", "Alice");
jedis.hset("user:1", "age", "30");
Map<String, String> user = jedis.hgetAll("user:1");

集合操作

java 复制代码
jedis.sadd("fruits", "apple", "banana", "orange");
Set<String> fruits = jedis.smembers("fruits");

有序集合操作

java 复制代码
jedis.zadd("scores", 85, "Alice");
jedis.zadd("scores", 90, "Bob");
Set<String> highScores = jedis.zrange("scores", 1, -1);

五、Jedis高级功能

事务操作

java 复制代码
Transaction tx = jedis.multi();
tx.set("key1", "value1");
tx.set("key2", "value2");
List<Object> results = tx.exec();

管道操作

java 复制代码
Pipeline pipeline = jedis.pipelined();
pipeline.set("key1", "value1");
pipeline.set("key2", "value2");
pipeline.sync();

订阅发布

java 复制代码
// 发布
jedis.publish("news", "Hello, Redis!");

// 订阅
new Thread(() -> {
    try (Jedis subJedis = pool.getResource()) {
        subJedis.subscribe((channel, message) -> System.out.println(message), "news");
    }
}).start();

六、Jedis性能优化

连接池配置

合理配置连接池参数,如最大连接数、超时时间等,可有效提升性能。

批量操作

使用管道或事务进行批量操作,减少网络往返时间。

数据序列化

对于复杂对象,使用序列化工具(如Jackson)转换为JSON字符串存储,提升读写效率。

七、Jedis注意事项

线程安全

Jedis实例非线程安全,多线程场景需使用连接池。

资源释放

使用完毕需及时释放连接,避免资源泄漏。

版本兼容性

不同版本Jedis支持的Redis命令不同,使用时需注意版本匹配。

八、总结

Jedis功能丰富,能满足多种场景需求。但需合理配置连接池、及时释放资源,并关注版本兼容性。

相关推荐
*小海豚*3 分钟前
在linux服务器上DNS正常,但是java应用调用第三方解析域名报错
java·linux·服务器
JustDI-CM5 分钟前
AI学习笔记-提示词工程
人工智能·笔记·学习
悟纤5 分钟前
学习与专注音乐流派 (Study & Focus Music):AI 音乐创作终极指南 | Suno高级篇 | 第33篇
大数据·人工智能·深度学习·学习·suno·suno api
爱写bug的野原新之助6 分钟前
加密摘要算法MD5、SHA、HMAC:学习笔记
笔记·学习
撩得Android一次心动19 分钟前
Android LiveData 全面解析:使用Java构建响应式UI【源码篇】
android·java·android jetpack·livedata
组合缺一23 分钟前
Solon AI (Java) v3.9 正式发布:全能 Skill 爆发,Agent 协作更专业!仍然支持 java8!
java·人工智能·ai·llm·agent·solon·mcp
MSTcheng.27 分钟前
【C++】C++11新特性(二)
java·开发语言·c++·c++11
一 乐31 分钟前
校园二手交易|基于springboot + vue校园二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
KIKIiiiiiiii31 分钟前
微信个人号API二次开发中的解决经验
java·人工智能·python·微信
80530单词突击赢32 分钟前
SpringBoot整合SpringMVC全解析
java·spring boot·后端