Springboot/Springcloud項(xiàng)目集成redis進(jìn)行存取的過程解析
前言:Redis支持五種數(shù)據(jù)類型:string(字符串),hash(哈希),list(列表),set(集合),zset(sorted set:有序集合)。
一、redis去官網(wǎng)https://redis.io/download下載后解壓
然后點(diǎn)擊里面的redis-server.exe(windows平臺(tái))即可正常啟動(dòng)

二、在項(xiàng)目中添加redis依賴
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
三、redis的使用
在需要使用redis的地方通過注解注入,比如在Controller中添加
@RestController
public class RedisController {
@Autowired
private StringRedisTemplate stringRedisTemplate;//只支持redis五大類型中的字符串類型
@Autowired
private RedisTemplate redisTemplate;//支持redis五大類型中的所有類型
}
四、字符串類型存?。╧,v)
@RequestMapping("/setString")
public Object setString(){
stringRedisTemplate.boundValueOps("s").set("辣椒");//存入
return stringRedisTemplate.boundValueOps("s").get();//讀取
}
訪問接口查看結(jié)果:

五、存取對(duì)象(k,object)
使用你自己的對(duì)象進(jìn)行存取,我這里使用Person對(duì)象
package com.star.pojo;
import java.io.Serializable;
public class Person implements Serializable {
private String name;
private int age;
private String Add;
public Person() {
}
public Person(String name, int age, String add) {
this.name = name;
this.age = age;
Add = add;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getAdd() {
return Add;
}
public void setAdd(String add) {
Add = add;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
", Add='" + Add + '\'' +
'}';
}
}
Person.java
@RequestMapping("/setPerson")
public Object setPerson(){
Person person = new Person("魚er", 151, "北京");
redisTemplate.boundValueOps("p").set(person);//存入
return redisTemplate.boundValueOps("p").get();//讀取
}

六、List類型(k,list)
@RequestMapping("/setList")
public List<String> setListRedis(){
List<String> list=new ArrayList<>();
list.add("手頭");
list.add("蘋果");
list.add("辣椒");
this.redisTemplate.boundValueOps("listk").set(list);//存入
return (List<String>) this.redisTemplate.boundValueOps("listk").get();//讀取
}

七、Hash類型(K,k,value)
@RequestMapping("/setHash")
public List<String> setHash(){
List<String> list=new ArrayList<>();
list.add("大書");
list.add("酸菜");
list.add("雞蛋");
this.redisTemplate.boundHashOps("thing").put("h",list);//存入
return (List<String>) this.redisTemplate.boundHashOps("thing").get("h");//讀取
}

八、然后打開redis desktop manager工具可以看到你存儲(chǔ)的數(shù)據(jù)
其安裝及連接方式不用多說,基本是個(gè)人都會(huì),實(shí)在不會(huì)可以去這里瞧瞧。

九、如果想要在單元測(cè)試中進(jìn)行存取
添加測(cè)試依賴,Junit必須4.12以上
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
在要進(jìn)行存取的類上添加注解@RunWith、@SpringBootTest,意思是啟動(dòng)單元測(cè)試時(shí)啟動(dòng)當(dāng)前項(xiàng)目的啟動(dòng)類,因?yàn)閱?dòng)類里面的@SpringBootApplication里面包含了包掃描@ComponentScan,不然注入StringRedisTemplate或RedisTemplate時(shí)注入失敗報(bào)空指針,當(dāng)然也可以在啟動(dòng)類里面返回new StringRedisTemplate或new RedisTemplate并且加注解@Bean的方式處理注入失敗問題,這里直接通過加注解的方式處理。
@RunWith(value = SpringJUnit4ClassRunner.class)
//RedisApp為啟動(dòng)類名字
@SpringBootTest(classes = {RedisApp.class})
public class RedisAppTest {
@Autowired
private StringRedisTemplate stringRedisTemplate;
@Autowired
private RedisTemplate redisTemplate;
@Test
public void setStringRedis(){
this.stringRedisTemplate.boundValueOps("name2").set("熊大");
System.out.println("ok");
}
@Test
public void getStringRedis(){
String name = this.stringRedisTemplate.boundValueOps("name2").get();
System.out.println("ok:"+name);
}
}
在redis desktop manager工具中可以看到存儲(chǔ)成功了,在控制臺(tái)也可以讀取


九、實(shí)際使用思路
@Autowired
private RedisTemplate redisTemplate;
/**
* 首次訪問時(shí),如果redis沒有數(shù)據(jù),就訪問數(shù)據(jù)庫,然后把訪問到的數(shù)據(jù)存到redis
* 后續(xù)訪問時(shí),直接查詢r(jià)edis
*/
@Override
public List<Person> findByPersonId(Long id) {// 先查看緩存中有沒有
List<Person> list = (List<Person>) redisTemplate.boundValueOps(id).get(); if(list==null){
System.out.println("redis中沒有,開始從數(shù)據(jù)庫中獲取");
......... //查詢數(shù)據(jù)庫得到List<Person> list =xxxxxx;
redisTemplate.boundValueOps(id).set(list);//將從數(shù)據(jù)庫查到的數(shù)據(jù)添加到redis中以備下次查找
}else{
System.out.println("redis中存在,list是直接從緩存中獲取的,沒查數(shù)據(jù)庫");
}
return list;
}
到此這篇關(guān)于Springboot/Springcloud項(xiàng)目中集成redis進(jìn)行存取的文章就介紹到這了,更多相關(guān)Springcloud集成redis存取內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Redis數(shù)據(jù)結(jié)構(gòu)之鏈表詳解
大家好,本篇文章主要講的是Redis數(shù)據(jù)結(jié)構(gòu)之鏈表詳解,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12
Win10配置redis服務(wù)實(shí)現(xiàn)過程詳解
這篇文章主要介紹了Win10配置redis服務(wù)實(shí)現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07
redis緩存數(shù)據(jù)庫中數(shù)據(jù)的方法
這篇文章主要為大家詳細(xì)介紹了redis緩存數(shù)據(jù)庫中數(shù)據(jù)的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07
Redis發(fā)布訂閱和實(shí)現(xiàn).NET客戶端詳解
發(fā)布訂閱在應(yīng)用級(jí)其作用是為了減少依賴關(guān)系,通常也叫觀察者模式。主要是把耦合點(diǎn)單獨(dú)抽離出來作為第三方,隔離易變化的發(fā)送方和接收方。下面這篇文章主要給大家介紹了關(guān)于Redis發(fā)布訂閱和實(shí)現(xiàn).NET客戶端的相關(guān)資料,需要的朋友可以參考下2017-03-03

