SpringBoot集成Redis的思路詳解
SpringBoot集成Redis
1、概述
Redis是什么?
Redis(Remote Dictionary Server ),即遠(yuǎn)程字典服務(wù)。
是一個(gè)開(kāi)源的使用ANSI C語(yǔ)言編寫(xiě)、支持網(wǎng)絡(luò)、可基于內(nèi)存亦可持久化的日志型、Key-Value數(shù)據(jù)庫(kù),并提供多種語(yǔ)言的API。
與memcached一樣,為了保證效率,數(shù)據(jù)都是緩存在內(nèi)存中。區(qū)別的是redis會(huì)周期性的把更新的數(shù)據(jù)寫(xiě)入磁盤(pán)或者把修改操作寫(xiě)入追加的記錄文件,并且在此基礎(chǔ)上實(shí)現(xiàn)了master-slave(主從)同步。
Redis能該干什么?
內(nèi)存存儲(chǔ)、持久化,內(nèi)存是斷電即失的,所以需要持久化(RDB、AOF)高效率、用于高速緩沖發(fā)布訂閱系統(tǒng)地圖信息分析計(jì)時(shí)器、計(jì)數(shù)器(eg:瀏覽量)… …
特性
多樣的數(shù)據(jù)類(lèi)型
持久化
集群
事務(wù)
…
2、測(cè)試Redis
SpringBoot操作數(shù)據(jù),Spring-Data、 jbdc、redis… …
SpringData與SpringBoot齊名的項(xiàng)目!
說(shuō)明:在SpringBoot2.x之后,原來(lái)使用的jedis被替換為lettuce
jedis:采用的直連,多個(gè)線程操作的話,是不安全的,如果想要避免不安全的,需使用jedis pool連接池!像BIO模式
lettuce:采用netty,實(shí)例可以再多個(gè)線程中進(jìn)行共享,不存在線程不安全的情況!可以減少線程數(shù)據(jù),更像NIO模式
新建一個(gè)項(xiàng)目
注意:
查看底層
源碼分析:
@Bean @ConditionalOnMissingBean( //如果未注入組件條件,我們自己可以定義一個(gè)redisTemplate來(lái)替換這個(gè)默認(rèn)的 name = {"redisTemplate"} ) public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException { //默認(rèn)的 RedisTemplate 沒(méi)有過(guò)多的設(shè)置 redis 都是需要序列化的 ! //兩個(gè)泛型都是 Object Object的類(lèi)型,我們往后使用需要強(qiáng)制轉(zhuǎn)換<String,String> RedisTemplate<Object, Object> template = new RedisTemplate(); template.setConnectionFactory(redisConnectionFactory); return template; } @Bean @ConditionalOnMissingBean //由于String 是redis 中最常用的類(lèi)型 所有說(shuō)單獨(dú)提出來(lái)一個(gè)bean! public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException { StringRedisTemplate template = new StringRedisTemplate(); template.setConnectionFactory(redisConnectionFactory); return template; }
1、導(dǎo)入依賴(lài)
2、配置連接
# SpringBoot 所有的配置類(lèi) 都有一個(gè)自動(dòng)配置類(lèi) RedisAutoConfiguration # 自動(dòng)配置類(lèi)都會(huì)綁定一個(gè) properties 配置文件 RedisProperties #配置 redis spring.redis.host=127.0.0.1 spring.redis.port=6379 spring.redis
3、測(cè)試!
package com.kk; import org.junit.jupiter.api.Test; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.data.redis.connection.RedisConnection; import org.springframework.data.redis.core.RedisTemplate; @SpringBootTest class Redis01SpringbootApplicationTests { @Autowired private RedisTemplate redisTemplate; @Test void contextLoads() { /* redisTemplate opsForValue 操作字符串的 類(lèi)似String opsForList 操作List 類(lèi)似List opsForSet opsForHash opsForZSet opsForGeo opsForHyperLogLog 除了基本的操作 ,我們常用的方法都可以直接通過(guò)redisTemplate 比如事務(wù)和基本的CRUD */ //獲取redis的連接對(duì)象 // RedisConnection connection = redisTemplate.getConnectionFactory().getConnection(); // connection.flushDb(); // connection.flushAll(); redisTemplate.opsForValue().set("kk1","kk2"); System.out.println(redisTemplate.opsForValue().get("kk1")); } }
3、自定義redisTemplate
首先先建一個(gè)實(shí)體類(lèi),測(cè)試
User類(lèi)
package com.kk.pojo; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; import org.springframework.stereotype.Component; import java.io.Serializable; @Component @Data @AllArgsConstructor @NoArgsConstructor //在企業(yè)中,我們所有的pojo都會(huì)序列化 public class User implements Serializable { private String name; private int age; }
測(cè)試:
@Test public void test() throws JsonProcessingException { //真實(shí)的開(kāi)發(fā)一般都使用json來(lái)傳遞對(duì)象 User user = new User("kk", 17); String jsonUser = new ObjectMapper().writeValueAsString(user);//這樣就變成了一個(gè)json對(duì)象了 redisTemplate.opsForValue().set("user",jsonUser); System.out.println(redisTemplate.opsForValue().get("user")); }
r = new ObjectMapper().writeValueAsString(user);//這樣就變成了一個(gè)json對(duì)象了 redisTemplate.opsForValue().set(“user”,jsonUser); System.out.println(redisTemplate.opsForValue().get(“user”)); }
==注意:如果不在User類(lèi)中實(shí)現(xiàn)序列化,它會(huì)報(bào)錯(cuò)==
到此這篇關(guān)于SpringBoot集成Redis的文章就介紹到這了,更多相關(guān)SpringBoot集成Redis內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
為什么RedisCluster設(shè)計(jì)成16384個(gè)槽
本文主要介紹了為什么RedisCluster設(shè)計(jì)成16384個(gè)槽,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09詳解redis腳本命令執(zhí)行問(wèn)題(redis.call)
這篇文章主要介紹了redis腳本命令執(zhí)行問(wèn)題(redis.call),分別介紹了redis-cli命令行中執(zhí)行及l(fā)inux命令行中執(zhí)行問(wèn)題,本文給大家介紹的非常詳細(xì),需要的朋友參考下吧2022-03-03Redis?Server啟動(dòng)過(guò)程的詳細(xì)步驟
本文主要介紹了Redis?Server啟動(dòng)過(guò)程的詳細(xì)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02一文搞懂Redis中String數(shù)據(jù)類(lèi)型
string 是 redis 最基本的類(lèi)型,你可以理解成與 Memcached 一模一樣的類(lèi)型,一個(gè) key 對(duì)應(yīng)一個(gè) value。今天通過(guò)本文給大家介紹下Redis中String數(shù)據(jù)類(lèi)型,感興趣的朋友一起看看吧2022-04-04CentOS Linux系統(tǒng)下安裝Redis過(guò)程和配置參數(shù)說(shuō)明
這篇文章主要介紹了CentOS Linux系統(tǒng)下安裝Redis過(guò)程和配置參數(shù)說(shuō)明,需要的朋友可以參考下2014-10-10Govern Service 基于 Redis 的服務(wù)治理平臺(tái)安裝過(guò)程詳解
Govern Service 是一個(gè)輕量級(jí)、低成本的服務(wù)注冊(cè)、服務(wù)發(fā)現(xiàn)、 配置服務(wù) SDK,通過(guò)使用現(xiàn)有基礎(chǔ)設(shè)施中的 Redis 不用給運(yùn)維部署帶來(lái)額外的成本與負(fù)擔(dān),接下來(lái)通過(guò)本文給大家分享Govern Service 基于 Redis 的服務(wù)治理平臺(tái)的相關(guān)知識(shí),感興趣的朋友一起看看吧2021-05-05redis?sentinel監(jiān)控高可用集群實(shí)現(xiàn)的配置步驟
這篇文章主要介紹了redis?sentinel監(jiān)控高可用集群實(shí)現(xiàn)的配置步驟,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-04-04詳解redis是如何實(shí)現(xiàn)隊(duì)列消息的ack
這篇文章主要介紹了關(guān)于redis是如何實(shí)現(xiàn)隊(duì)列消息的ack的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-04-04Redis實(shí)戰(zhàn)之商城購(gòu)物車(chē)功能的實(shí)現(xiàn)代碼
這篇文章主要介紹了Redis實(shí)戰(zhàn)之商城購(gòu)物車(chē)功能的實(shí)現(xiàn)代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02