文章目录
- 🍃前言
- 🎄Spring Boot连接redis客户端
- 🚩项目的创建
- 🚩配置端⼝转发
- 🚩配置 redis 服务地址
- 🚩更改 Redis 配置文件
- 🚩使用 StringRedisTemplate 类操作
- 🎍Spring Boot操作Redis客户端
- ⭕总结
🍃前言
Spring Boot 系列内置的 Redis 是 Lettuce, 和 Jedis 的使⽤还是存在⼀定的差异.
对于 Jedis 来说, 各个⽅法和 Redis的命令基本是⼀致的.
⽽集成到 Spring Boot 之后,接⼝上和原始 Redis 命令存在部分差别,但是使⽤起来也并不困难,很容易可以通过⽅法名字理解⽤法。
下面这篇文章的内容主要内容就为 Spring Boot如何连接 Redis 客户端 与 Spring Boot使用redis的一些命令
🎄Spring Boot连接redis客户端
Spring Boot连接redis客户端主要分为以下几个步骤:
- 项目的创建
- 配置端口转发
- 配置 redis 服务地址
- 更改 Redis 配置文件
- 使用 StringRedisTemplate 类操作
🚩项目的创建
勾选 NoSQL 中的Spring Data Redis
当然,把 Web 中的 Spring Web 也勾选⼀下,⽅便写接⼝进⾏后续测试.
🚩配置端⼝转发
edis 服务器安装在云服务器上, ⽽我们编写的代码则是在本地主机.
要想让本地主机能访问 redis, 需要把 redis 的端⼝(默认:6379)通过云服务器后台⻚⾯的 “防⽕墙” / "安全组"放开端⼝到公⽹上.
但是这个操作⾮常危险(⿊客会顺着redis 端⼝进来)。因此我们可以使⽤端⼝转发的⽅式, 直接把服务器的 redis 端⼝映射到本
博主使用的时 xshell 操作 linux 服务器,如果这部分还不会的小伙伴可以参考博主写的 【JavaEE进阶】使用云服务器实现Linux环境搭建
在 xshell 中, 进⾏如下配置:
- 右键云服务器的会话, 选择属性.
- 找到隧道 -> 配置转移规则
此处需要注意的是:
- 如果你之前已经连接上服务器,然后再进行配置,这时你需要重新断开进行连接
此时访问本地的 8888,就相当于访问对应服务器的 6379
这里我们也可以通过本地 cmd 输入以下命令查看我们所配置端口是否被使用来判断配置是否成功
🚩配置 redis 服务地址
在 application.yml 中配置
配置代码如下:
spring:redis:host: 127.0.0.1port: 8888
🚩更改 Redis 配置文件
我们想要通过该端口正确访问 Redis 时,我们还需要对 Redis 配置文件进行如下配置
首先我们使用vim命令进入,打开相应的配置文件,命令如下
vim /etc/redis/redis.conf
然后点击 i 进入插入模式进行修改,需要修改的点如下:
- 修改 bind 127.0.0.1 为 bind 0.0.0.0
- 修改 protected-mode yes 为 protected-mode no
最后按 Esc 键,并输入 :wq,按下enter键返回即可
🚩使用 StringRedisTemplate 类操作
创建一个 controller 类,并注入 StringRedisTemplate 类
代码示例如下:
@RestController
public class RedisController {@Autowiredprivate StringRedisTemplate redisTemplate;
}
后续操作通过操作 redisTemplate 实例实施redis命令
🎍Spring Boot操作Redis客户端
Spring Boot 重新封装了操作命令,分别通过上面所创建的redisTemplate实例的不同的方法进行调用不同类型的命令
- String类型:
redisTemplate.opsForValue()
- List类型:
redisTemplate.opsForList()
- 哈希类型:
redisTemplate.opsForHash()
- 集合类型:
redisTemplate.opsForSet()
- 有序集合类型:
redisTemplate.opsForZSet()
基础操作指令如下:
使用String类型:
@RequestMapping("testString")
public String testString() {redisTemplate.opsForValue().set("key", "value");String value = redisTemplate.opsForValue().get("key");System.out.println(value);redisTemplate.delete("key");return "OK";
}
使用List类型:
@RequestMapping("testList")
public String testList() {redisTemplate.opsForList().leftPush("key", "a");redisTemplate.opsForList().leftPushAll("key", "b", "c", "d");List<String> values = redisTemplate.opsForList().range("key", 1, 2);System.out.println(values);redisTemplate.delete("key");return "OK";
}
使用hash类型:
@RequestMapping("/testHash")
public String testHashmap() {redisTemplate.opsForHash().put("key", "name", "zhangsan");String value = (String) redisTemplate.opsForHash().get("key", "name");System.out.println(value);redisTemplate.opsForHash().delete("key", "name");boolean ok = redisTemplate.opsForHash().hasKey("key", "name");System.out.println(ok);redisTemplate.delete("key");return "OK";
}
使用set:
@RequestMapping("/testSet")
public String testSet() {redisTemplate.opsForSet().add("key", "aaa", "bbb", "ccc");boolean ok = redisTemplate.opsForSet().isMember("key", "aaa");System.out.println(ok);redisTemplate.opsForSet().remove("key", "aaa");long n = redisTemplate.opsForSet().size("key");System.out.println(n);redisTemplate.delete("key");return "OK";
}
使用zset:
@RequestMapping("/testZset")
public String testZSet() {redisTemplate.opsForZSet().add("key", "吕布", 100);redisTemplate.opsForZSet().add("key", "赵云", 98);redisTemplate.opsForZSet().add("key", "典⻙", 95);Set<String> values = redisTemplate.opsForZSet().range("key", 0, 2);System.out.println(values);long n = redisTemplate.opsForZSet().count("key", 95, 100);System.out.println(n);redisTemplate.delete("key");return "OK";
}
上面只是介绍使用了一些简单的命令,有需要的小伙伴可以查看专业文档进行详细学习
⭕总结
关于《【Redis】 Redis 集成到 Spring Boot上面》就讲解到这儿,感谢大家的支持,欢迎各位留言交流以及批评指正,如果文章对您有帮助或者觉得作者写的还不错可以点一下关注,点赞,收藏支持一下