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

相关推荐
想不明白的过度思考者几秒前
Java从入门到“放弃”(精通)之旅——类和对象全面解析⑦
java·开发语言
今麦郎xdu_几秒前
【数据结构】红黑树
数据结构·c++·算法·stl
工业互联网专业4 分钟前
基于springboot+vue的仓库管理系统
java·vue.js·spring boot·毕业设计·源码·课程设计·智能无人仓库管理
思麟呀5 分钟前
list的模拟实现和反向迭代器的底层
c语言·数据结构·c++·list
wolfengi5 分钟前
clickhouse数据导出导入
数据库·clickhouse
LucianaiB6 分钟前
C语言之机房机位预约系统
java·c语言·数据库
马达加斯加D9 分钟前
缓存 --- Redis性能瓶颈和大Key问题
数据库·redis·缓存
知其然亦知其所以然9 分钟前
大模型时代,Java开发者别落伍!LangChain4j让你轻松追上
java·人工智能·后端
极小狐12 分钟前
极狐GitLab 议题和史诗创建的速率限制如何设置?
linux·运维·数据库·git·安全·gitlab·极狐gitlab
bob_young17 分钟前
yocto编译使用共享缓存
缓存