Java 中使用 Redis

相关知识

RESP

Redis 服务器,在官网上公开了使用的协议,RESP

任何以一个第三方库都可以通过上述协议,来实现一个和 Redis 服务器通信的客户端程序

java 生态中,封装了 RESP 协议,实现的 Redis 客户端很多,此处使用 jedis

jedis 提供的 API 和 Redis 命令 高度一致

jedis 可以通过 Maven 来下载安装

准备工作

引入依赖

仓库地址 Maven Repository: redis.clients >> jedis

在创建 Maven 项目时,把 jedis 的依赖拷贝到 pom.xml 中

配置端口转发

java 的开发,是高度依赖 Windows(IDEA)

从 Redis 客户端 到 Redis 服务器,需要通过云服务器的外网 IP 来访问到 Linux 服务器

Redis 服务器安装在云服务器上,而编写的代码则在本地主机上

要想让本地主机能访问到 redis,需要把 redis 的端口通过云服务器后台页面的"防火墙/安全组"放开端口到公网上,但此操作身份危险(redis 端口会被入侵)

因此可以使用 端口转发 的方式,直接把服务器的 redis 端口映射到本地

直接让 java 程序在 Linux 服务器上运行,需要把代码打成 jar 包,再把 jar 拷贝到 Linux 服务器上执行

虽然在该过程中,可以通过一些第三方库简化上述操作,但是还是会过于繁杂

在 xshell 中,操作如下:

1)右键云服务器的对话,选择属性

2)点击隧道 -> 配置转移规则

3)使用该会话连接服务器

此时,访问本地的 8888 端口,就相当于是访问对应服务器的 6379 端口

xshell 必须与服务器处于连接状态,这样的映射才有效

操作原理

配置 ssh 端口转发,把云服务器上的 redis 端口,映射到本地主机

此处的操作是,ssh 进行端口的映射,把服务器的 6379 端口映射到 本地的 8888

在本地,xshell 远程连接到 Linux 服务器

ssh 协议 / 程序 默认走 22 端口

ssh 功能强大,支持端口转发,相当于是通过 ssh 的22端口,来传递其他端口的数据

本身我们需要通过 Windows 主机,访问云服务器的 6379 端口

于是构造了一个特殊的 ssh 数据报,把访问 Redis 的请求,放到 ssh 数据报里

这个数据报会通过 22 端口发送给服务器

Linux 服务器的 ssh 服务器程序会解析出上述的数据报

一个 linux 主机上,存在的服务器很多,ssh 可能需要给多个端口传递数据

此时,为了区分不同的端口,往往会把服务器的端口在本地用另外一个接来进行表示

------> ssh 端口转发 / ssh 端口映射 / ssh 隧道

注意:

1)当 ssh 连接上后,端口转发才生效(ssh 连接断开,端口转发失效)

配置之后,一定要断开之前的连接,重新连接才能生效

2)最开始安装 Redis 服务器时,要配置绑定的 IP,关闭保护模式

连接 Redis Server

1)使用 JedisPool 描述 Redis 服务器的位置,使用 URL 表示(后续根据实际情况进行改写)

2)使用 getResource 和服务器建立连接

3)连接使用完毕需要 close 关闭,也可以使用 try 自动关闭

4)通过 ping 方法可以检测连接是否正确建立

基础操作

jedis 这个库的本质是针对 Redis 的各种命令进行封装

调用某个方法,就相当于是在 Redis 客户端敲下相应的命令

通用操作

get set

exists del

del 可以删除多个 key, 以 变长参数列表 的方式体现. 返回值是实际删除的 key 的个数

keys

set 是无需唯一的,所以使用 Set 类型存储

expire ttl

复制代码

type

string

mget mset

getrange setrange

append

incr decr

list

lpush rpush lrange

rpop lpop

blpop brpop

当前数据库中没有元素,打开 Redis 客户端手动输入一段 list 类型的数据后,得到返回值

llen

set

sadd smembers

sismembers

scard

spop

sinter sinterstore

zset

zadd zrange

zcard

zrem

zscore

zrank

hash

hset hget

hexists

hdel

hkeys hvals

hmget hmset

相关推荐
许彰午7 分钟前
17_synchronized关键字深度解析
java·开发语言
闪电悠米1 小时前
黑马点评-Redis 消息队列-03_stream_consumer_group
开发语言·数据库·redis·分布式·缓存·junit·lua
小欣加油1 小时前
leetcode1926 迷宫中离入口最近的出口
数据结构·c++·算法·leetcode·职场和发展
DIY源码阁1 小时前
JavaSwing航班订票管理系统 - MySQL版
数据库·mysql
qqxhb1 小时前
47|成本与性能:缓存、批处理、模型路由与降级
缓存·批处理·智能模型路由·多级降级预案·成本预算
Xzh04232 小时前
AI Agent 学习路线(Java 后端方向)
java·人工智能·学习
艾利克斯冰2 小时前
Java 设计模式-行为型模式(更新中)
java·开发语言·设计模式
倒霉蛋小马2 小时前
Java新特性:record关键字
java·开发语言
浪客灿心3 小时前
项目篇:模块设计与实现
数据库·c++
折哥的程序人生 · 物流技术专研3 小时前
《Java 100 天进阶之路》第95篇:消息队列基础(RocketMQ/Kafka)(2026版)
java·面试·kafka·rocketmq·java-rocketmq·求职招聘