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é)果:
五、存取對象(k,object)
使用你自己的對象進(jìn)行存取,我這里使用Person對象
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ì)可以去這里瞧瞧。
九、如果想要在單元測試中進(jìn)行存取
添加測試依賴,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)單元測試時(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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Redis數(shù)據(jù)結(jié)構(gòu)之鏈表詳解
大家好,本篇文章主要講的是Redis數(shù)據(jù)結(jié)構(gòu)之鏈表詳解,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12Win10配置redis服務(wù)實(shí)現(xiàn)過程詳解
這篇文章主要介紹了Win10配置redis服務(wù)實(shí)現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07redis緩存數(shù)據(jù)庫中數(shù)據(jù)的方法
這篇文章主要為大家詳細(xì)介紹了redis緩存數(shù)據(jù)庫中數(shù)據(jù)的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07Redis發(fā)布訂閱和實(shí)現(xiàn).NET客戶端詳解
發(fā)布訂閱在應(yīng)用級其作用是為了減少依賴關(guān)系,通常也叫觀察者模式。主要是把耦合點(diǎn)單獨(dú)抽離出來作為第三方,隔離易變化的發(fā)送方和接收方。下面這篇文章主要給大家介紹了關(guān)于Redis發(fā)布訂閱和實(shí)現(xiàn).NET客戶端的相關(guān)資料,需要的朋友可以參考下2017-03-03