最近在使用Spring Boot,發(fā)現(xiàn)其功能真是強(qiáng)大,可以快速的集成很多的組件功能,非常方便:
成都創(chuàng)新互聯(lián)主打移動(dòng)網(wǎng)站、成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、網(wǎng)站改版、網(wǎng)絡(luò)推廣、網(wǎng)站維護(hù)、國際域名空間、等互聯(lián)網(wǎng)信息服務(wù),為各行業(yè)提供服務(wù)。在技術(shù)實(shí)力的保障下,我們?yōu)榭蛻舫兄Z穩(wěn)定,放心的服務(wù),根據(jù)網(wǎng)站的內(nèi)容與功能再?zèng)Q定采用什么樣的設(shè)計(jì)。最后,要實(shí)現(xiàn)符合網(wǎng)站需求的內(nèi)容、功能與設(shè)計(jì),我們還會(huì)規(guī)劃穩(wěn)定安全的技術(shù)方案做保障。今天就來介紹下,如何集成Redis。
定義
Redis 是一個(gè)高性能的key-value數(shù)據(jù)庫。它支持存儲(chǔ)的value類型很多,包括string(字符串)、list(鏈表)、set(集合)、zset(sorted set –有序集合)和hash(哈希類型)。
以下是Redis的一些優(yōu)點(diǎn)。
異常快 - Redis非???,每秒可執(zhí)行大約110000次的設(shè)置(SET)操作,每秒大約可執(zhí)行81000次的讀取/獲取(GET)操作。
支持豐富的數(shù)據(jù)類型 - Redis支持開發(fā)人員常用的大多數(shù)數(shù)據(jù)類型,例如列表,集合,排序集和散列等等。這使得Redis很容易被用來解決各種問題,因?yàn)槲覀冎滥男﹩栴}可以更好使用地哪些數(shù)據(jù)類型來處理解決。
操作具有原子性 - 所有Redis操作都是原子操作,這確保如果兩個(gè)客戶端并發(fā)訪問,Redis服務(wù)器能接收更新的值。
多實(shí)用工具 - Redis是一個(gè)多實(shí)用工具,可用于多種用例,如:緩存,消息隊(duì)列(Redis本地支持發(fā)布/訂閱),應(yīng)用程序中的任何短期數(shù)據(jù),例如,web應(yīng)用程序中的會(huì)話,網(wǎng)頁命中計(jì)數(shù)等。
如何搭建?
一.加入Redis相關(guān)依賴
二、application.properties中加入redis相關(guān)配置
在@Configuration或者集成了這個(gè)注解的注解標(biāo)識(shí)的類中聲明一個(gè)Redis的bean,本例是在入口類上聲明的Bean:
在Controller里注入StringRedisTemplate:
啟動(dòng)瀏覽器訪問:
以上是手動(dòng)進(jìn)行redis的操作,那如何進(jìn)行自動(dòng)的的緩存操作呢?
在啟動(dòng)類中添加注解
@EnableCaching會(huì)為每個(gè)bean中被 @Cacheable, @CachePut and @CacheEvict修飾的public方法進(jìn)行緩存操作。
緩存的用法
這個(gè)方法在userId相同形同的情況下,第一次調(diào)用的時(shí)候會(huì)執(zhí)行方法,以后每次在調(diào)用的時(shí)候會(huì)讀取緩存中的數(shù)據(jù)。
緩存的注解介紹:
@Cacheable
這個(gè)注解,會(huì)每次先檢查是否執(zhí)行過這個(gè)方法,在從緩存數(shù)據(jù)庫中查看key是否相等,如果找到了,從緩存中讀取,沒有匹配的那么執(zhí)行該方法,將結(jié)果緩存。
緩存都是通過key-value進(jìn)行儲(chǔ)存的,value或cacheNames必須指定(value是cacheNames的別名),指定多個(gè)value用(value = {"value1", "value2"})
如果沒有指定key,spring會(huì)提供一個(gè)默認(rèn)的KeyGenerator,這個(gè)KeyGenerator根據(jù)參數(shù)生成key,如果方法沒有參數(shù)返回KeyGenerator.EMPTY,如果有一個(gè)參數(shù)返回這個(gè)實(shí)例,如果有多個(gè)參數(shù)返回包含這些參數(shù)的SimpleKey??梢酝ㄟ^繼承CachingConfigurerSupport自己指定KeyGenerator,類上加@Configuration注解。也可以像上面那樣自己指定key,需要了解SPEL表達(dá)式。
多線程的情況下,可能同時(shí)會(huì)有多個(gè)線程同時(shí)進(jìn)入一個(gè)沒被緩存過的方法,這樣會(huì)導(dǎo)致多個(gè)線程都會(huì)執(zhí)行一遍方法,sync="true"會(huì)將第一次計(jì)算返回值的這個(gè)方法lock,計(jì)算完成后將結(jié)果緩存
備注:Redis最為常用的數(shù)據(jù)類型主要有以下:
總結(jié)
以上所述是小編給大家介紹的Spring Boot集成Redis實(shí)戰(zhàn)操作功能,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)創(chuàng)新互聯(lián)網(wǎng)站的支持!