【Redis系列】Java操作Redis客户端

【Redis系列】Java操作Redis客户端


🚀 欢迎来到我的ZEEKLOG博客:Optimistic _ chen
一名热爱技术与分享的全栈开发者,在这里记录成长,专注分享编程技术与实战经验,助力你的技术成长之路,与你共同进步!


🚀我的专栏推荐

专栏内容特色适合人群
🔥C语言从入门到精通系统讲解基础语法、指针、内存管理、项目实战零基础新手、考研党、复习
🔥Java基础语法系统解释了基础语法、类与对象、继承Java初学者
🔥Java核心技术面向对象、集合框架、多线程、网络编程、新特性解析有一定语法基础的开发者
🔥Java EE 进阶实战Servlet、JSP、SpringBoot、MyBatis、项目案例拆解想快速入门Java Web开发的同学
🔥Java数据结构与算法图解数据结构、LeetCode刷题解析、大厂面试算法题面试备战、算法爱好者、计算机专业学生
🔥Redis系列从数据类型到核心特性解析项目必备

🚀我的承诺:
✅ 文章配套代码:每篇技术文章都提供完整的可运行代码示例

✅ 持续更新:专栏内容定期更新,紧跟技术趋势

✅ 答疑交流:欢迎在文章评论区留言讨论,我会及时回复(支持互粉)


🚀 关注我,解锁更多技术干货!
⏳ 每天进步一点点,未来惊艳所有人!✍️ 持续更新中,记得⭐
收藏关注⭐不迷路 ✨

📌 标签:#技术博客#编程学习#Java#C语言#算法#程序员

文章目录

前言

【Redis系列】常用数据结构—String
【Redis系列】常用数据结构—Hash类型
【Redis系列】常用数据结构—List类型
【Redis系列】常用数据结构—SET类型
【Redis系列】常用数据结构—ZSET类型
前面的学习主要是各种redis的基本操作/命令,都是在redis命令行客户端手动执行的,这种方式对于日常开发来说很难上手使用,所以更多时候,程序员们都使用redis的api,使用定制化的redis客户端程序,进一步操作redis服务器(这种操作类似使用MyBatis操作数据库),用程序来操作redis服务器。

Jedis

因为redis官方公布了redis服务器使用的协议:RESP。所以任何人都可以通过这个协议来实现一个和redis服务器通信的客户端程序。我们可以将各大佬做好的客户端库直接调用(反正我实现不了)。Java体系中封装了RESP协议,有很多大佬实现了redis客户端的库,今天我们使用jedis库,通过maven引入。


现在我们的redis客户端就在我们的idea上,而redis服务器却在我的云服务器上,两者之间的通信必须经过外网IP来访问到我的服务器,才能到达redis服务器。

在这里插入图片描述

这种情况,

  1. 要么我把程序打一个jar包,把jar包拷贝到Linux服务器上去执行

要么配置ssh端口转发,把云服务器的redis通信端口,映射到本地主机。

在这里插入图片描述

很明显,选择第二种方法会更加方便,否则redis每次进行通信都要对程序进行打包。

ssh端口转发


那么问题来了,SSH是怎么进行端口转发的?


SSH(Secure Shell) 是一种网络协议,用于在不安全的网络(如互联网)上提供安全的远程登录和安全的网络服务。
我们的XShell中就有这种协议,XShell远程登录到云服务器,通过SSH协议完成本地端口转发,将远程服务的端口映射到本地。

在这里插入图片描述


ssh默认走22端口,整个过程就是在本地构造一个ssh数据报,把对redis的通信放到ssh数据报中,整个数据报通过ssh的22端口发送给云服务器,云服务器解析数据报,然后把数据交给redis6379端口,完成整个通信过程。

后续Java代码中,通过127.0.0.1:8888就能操作到云服务器中的redis了。

注意:除了配置ssh端口映射之外,还要修改redis服务器的配置,修改绑定的ip( 默认只能本机访问,不能跨主机访问);以及关闭保护模式(默认是yes,不能跨主机访问)

连接redis服务器

创建maven项目,引入jedis的依赖到pom.xml中

<!-- https://mvnrepository.com/artifact/redis.clients/jedis --> <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>4.3.2</version> </dependency> 
  • 使⽤JedisPool描述Redis服务器的位置.使⽤url来表⽰
  • 使用getResource和服务器建立连接
//连接到redis服务器上 JedisPool jedisPool=new JedisPool("tcp://127.0.0.1:8888");try(Jedis jedis=jedisPool.getResource()){ String pong=jedis.ping(); System.out.println(pong);}
  • 连接使用完后要close关闭,也可以使用try自动关闭

通过ping检测连接是否建立

在这里插入图片描述


getResource() 就像去图书馆借书,不是买新书(创建连接),而是从书库(jedisPool连接池)里借一本已有的书,用完要还(close()),这样别人才能继续借。

Java操作命令

在程序中调用方法,其实和我们在命令行客户端中是一样的,只是把命令变为被调用的方法。因为之前我们系统写过基本的命令, 这里只简单展示一下即可。

通用命令

set和get

publicstaticvoidtest1(Jedis jedis){System.out.println("get和set的使用");//先情况数据库,避免上一组数据影响下一组测试 jedis.flushAll(); jedis.set("key1","111"); jedis.set("key2","222");String value1=jedis.get("key1");System.out.println("value"+value1);String value2=jedis.get("key2");System.out.println("value"+value2);}publicstaticvoidmain(String[] args){//连接到redis服务器上JedisPool jedisPool=newJedisPool("tcp://127.0.0.1:8888");try(Jedis jedis=jedisPool.getResource()){String pong=jedis.ping();System.out.println(pong);test1(jedis);test2(jedis);}}
在这里插入图片描述

exists和del

  • exists 命令来检查给定的键是否存在。该命令会返回一个整数,表示键是否存在:1 表示存在,0 表示不存在
  • del可以删除多个key,以变长参数列表的方式体现,返回值是实际删除的key的个数
private static void test2(Jedis jedis){ jedis.set("key1","111"); jedis.set("key2","222"); jedis.set("key3","333");//检测key1是否存在 boolean ret=jedis.exists("key1"); System.out.println(ret);//删除key1 long n=jedis.del("key1"); System.out.println(n);//检测key1是否存在 ret=jedis.exists("key1"); System.out.println(ret);//批量删除 n=jedis.del("key3","key2"); System.out.println(n);}
在这里插入图片描述

string类型命令

append

append:字符串追加

private static void test3(Jedis jedis){ jedis.append("key2","hello "); String value=jedis.get("key2"); System.out.println(value); jedis.append("key2","redis String"); value=jedis.get("key2"); System.out.println(value);}
在这里插入图片描述

incrby 和 decrby

  • incrby对key的数值增加指定数量。如果不存在该键,则在执行递增前将其初始化为0。该命令是原子命令,仅对数值有效。
  • decrby对密钥的数值减少指定数量。如果不存在该键,则在执行递减前将其初始化为0。该命令是原子命令,仅对数值有效。
private static void test4(Jedis jedis){ jedis.set("key","0"); jedis.incrBy("key",5);//+5 System.out.println(jedis.get("key")); jedis.decrBy("key",3);//-3 System.out.println(jedis.get("key"));}
在这里插入图片描述

list类型命令

lrange

  • lrange获取指定区间元素
private static void test5(Jedis jedis){ jedis.rpush("list","1","2","3","4"); List<String> values=jedis.lrange("list",1,3); System.out.println(values);}
在这里插入图片描述

linsert

  • 通过 ListPosition.BEFORE ListPosition.AFTER 标识插⼊位置.
private static void test6(Jedis jedis){ jedis.rpush("list2","a","b","c","e"); jedis.linsert("list2", ListPosition.BEFORE,"e","d"); List<String> values=jedis.lrange("list2",0,-1); System.out.println(values);}
在这里插入图片描述

Hash类型

hkeys 和 hvals

  • hkeys返回哈希表中所有键的列表。返回列表中字段的顺序无法保证
  • hvals返回哈希表中所有值的列表。返回列表中值的顺序与 HKEYS 返回的字段顺序相对应
private static void test7(Jedis jedis){ jedis.hset("hash1","name","zhangsan"); jedis.hset("hash1","age","20");Set<String> keys=jedis.hkeys("hash1"); System.out.println(keys); List<String> values=jedis.hvals("hash1"); System.out.println(values);}
在这里插入图片描述

set命令

srem 和 sismember

  • srem:删除集合中的指定元素,如果删除成功返回1,如果不存在则什么都不做返回0;如果指定的键不是集合类型则会报错。
  • sismember:查看一个元素是否在集合中,如果在集合中返回1,如果不在集合中,或者指定集合的键不存在则返回0;如果指定的键存在但是不是集合类型则会报错。
private static void test8(Jedis jedis){ jedis.sadd("set1","aaa","bbb","ccc"); boolean ret=jedis.sismember("set1","bbb"); System.out.println(ret); long n= jedis.srem("set1","aaa","bbb"); System.out.println(n); ret=jedis.sismember("set1","aaa"); System.out.println(ret); ret=jedis.sismember("key1","111"); System.out.println(ret);}
在这里插入图片描述


在这里插入图片描述

sdiff

  • sdiff求差集,返回结果列表
private static void test9(Jedis jedis){ jedis.sadd("set2","aaa","bbb","ccc","ddd"); jedis.sadd("set3","aaa","eee","ccc","fff");Set<String> ret=jedis.sdiff("set2","set3"); System.out.println(ret);}
在这里插入图片描述

ZSet类型

zcard 和 zscore

  • zcard返回 key 的成员个数。 key不存在时,返回0
  • zscore返回指定 key 和 member 的 分数值
private static void test10(Jedis jedis){ jedis.zadd("zset",100,"张三"); jedis.zadd("zset",99,"李四"); jedis.zadd("zset",94,"赵六"); jedis.zadd("zset",96,"王五"); jedis.zadd("zset",80,"小王"); jedis.zadd("zset",85,"小赵"); long n=jedis.zcard("zset"); System.out.println(n); double score=jedis.zscore("zset","小王"); System.out.println(score);}
在这里插入图片描述

zinterstore

  • zinterstore计算多个有序集合的交集,并将结果存储在新的有序集合中
private static void test11(Jedis jedis){ jedis.zadd("zset1",100,"张三"); jedis.zadd("zset1",99,"李四"); jedis.zadd("zset1",85,"小赵"); jedis.zadd("zset2",100,"张三"); jedis.zadd("zset2",99,"李四"); jedis.zadd("zset2",94,"赵六"); jedis.zadd("zset2",96,"王五"); jedis.zadd("zset2",80,"小王"); jedis.zadd("zset2",85,"小赵"); long n=jedis.zinterstore("zset3","zset1","zset2"); System.out.println(n);//Tuple元组是一种数据结构,可以容纳固定数量的元素,每个元素可能类型不同 List<Tuple> tuples=jedis.zrangeWithScores("zset3",0,-1); System.out.println(tuples);}
在这里插入图片描述

完结撒花!🎉

如果这篇博客对你有帮助,不妨点个赞支持一下吧!👍
你的鼓励是我创作的最大动力~

想获取更多干货? 欢迎关注我的专栏 → optimistic_chen
📌 收藏本文,下次需要时不迷路!

我们下期再见!💫 持续更新中……


悄悄说:点击主页有更多精彩内容哦~ 😊

在这里插入图片描述

Read more

【C++贪心】P8769 [蓝桥杯 2021 国 C] 巧克力|普及+

【C++贪心】P8769 [蓝桥杯 2021 国 C] 巧克力|普及+

本文涉及知识点 C++贪心 [蓝桥杯 2021 国 C] 巧克力 题目描述 小蓝很喜欢吃巧克力,他每天都要吃一块巧克力。 一天小蓝到超市想买一些巧克力。超市的货架上有很多种巧克力,每种巧克力有自己的价格、数量和剩余的保质期天数,小蓝只吃没过保质期的巧克力,请问小蓝最少花多少钱能买到让自己吃 x x x 天的巧克力。 输入格式 输入的第一行包含两个整数 x x x, n n n,分别表示需要吃巧克力的天数和巧克力的种类数。 接下来 n n n 行描述货架上的巧克力,其中第 i i i 行包含三个整数 a i a_i ai , b i b_i bi

By Ne0inhk
C++起始之路——模板进阶

C++起始之路——模板进阶

💁‍♂️个人主页:进击的荆棘 👇作者其它专栏: 《数据结构与算法》《算法》《C++起始之路》 目录 1.非类型模板参数 2.模板的特化 3.模板分离编译 4.模板总结 1.非类型模板参数 模板参数分类类型形参与非类型形参。 类型形参即:出现在模板参数列表中,跟在class或typename之类的后面的参数类型名称。 非类型形参,就是用一个常量作为类(函数)模板的一个参数,在类(函数)模板中可将该参数当成常量来使用。 namespace Achieve{ //定义一个模板类型的静态数组 tempalte<class T,size_t N=10> class array{ public: T& operator[](size_t index)

By Ne0inhk
C++微服务实战中好友管理子服务的全面解析

C++微服务实战中好友管理子服务的全面解析

【C++ 微服务实战】IM 好友管理子服务全解析:从 Proto 定义到高可用部署 在即时通讯(IM)系统中,好友管理子服务是连接 “用户社交关系” 与 “聊天会话” 的核心枢纽 —— 它既要处理好友申请、关系维护,也要管理单聊 / 群聊会话的创建与成员维护。本文基于实际项目代码(C++/brpc/Protobuf/ODB),从 “接口设计”“数据模型”“核心逻辑”“高可用部署” 四个维度,完整拆解好友管理子服务的实现细节,带你理解如何构建一个解耦、可靠的微服务。 一、服务定位与技术栈 在 IM 微服务架构中,好友管理子服务(Friend Server)的核心职责是 **“管理用户社交关系” 与 “维护聊天会话容器”**,向上对接网关服务接收客户端请求,向下依赖 MySQL/ES 存储数据,

By Ne0inhk
Microsoft Visual C++ 运行库安装教程(2025 最新版全版本修复指南)

Microsoft Visual C++ 运行库安装教程(2025 最新版全版本修复指南)

前言 在使用大型软件、开发工程项目或玩 3A 游戏时,很多人都遇到过这样的报错: “缺少 msvcp140.dll” “无法继续执行代码,因为系统找不到 vcruntime140_1.dll” “程序无法启动,因为计算机中丢失了 MSVCR100.dll” 这些提示看似复杂,其实本质是 Microsoft Visual C++ 运行库(VC++ Redistributable)缺失或损坏 所致。 本文将带来 2025 年最新版 Microsoft Visual C++ 运行库安装教程,无论你是游戏玩家、开发者还是普通用户,都能找到最合适的解决方案。内容涵盖: * 一键修复方法(适合新手,快速解决 DLL 报错) * 手动下载安装方案(适合专业或开发用途) * 常见 DLL 报错与完整修复思路 * 系统维护与预防技巧

By Ne0inhk