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

相关推荐
桦说编程4 小时前
Java 中如何创建不可变类型
java·后端·函数式编程
lifallen4 小时前
Java Stream sort算子实现:SortedOps
java·开发语言
IT毕设实战小研4 小时前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
wyiyiyi5 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
没有bug.的程序员5 小时前
JVM 总览与运行原理:深入Java虚拟机的核心引擎
java·jvm·python·虚拟机
天宇_任5 小时前
Mysql数据库迁移到GaussDB注意事项
数据库·mysql·gaussdb
甄超锋5 小时前
Java ArrayList的介绍及用法
java·windows·spring boot·python·spring·spring cloud·tomcat
星星火柴9366 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
阿华的代码王国6 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
Zyy~6 小时前
《设计模式》装饰模式
java·设计模式