欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

redis中使用bloomfilter的白名單功能解決緩存穿透問題

 更新時間:2023年07月26日 11:47:09   作者:健康平安的活著  
本文主要介紹了redis中使用bloomfilter的白名單功能解決緩存穿透問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

一 緩存預熱

1.1 緩存預熱

將需要的數(shù)據(jù)提前緩存到緩存redis中,可以在服務啟動時候,或者在使用前一天完成數(shù)據(jù)的同步等操作。保證后續(xù)能夠正常使用。

1.2 緩存穿透

在redis中,查詢redis緩存數(shù)據(jù)沒有內(nèi)容,接著查詢mysql數(shù)據(jù)庫,也沒有需要的內(nèi)容,做了兩次無用的查詢。進而造成mysql數(shù)據(jù)庫的負擔,造成一系列的風險。

解決辦法:bloomfilter+白名單實現(xiàn)過濾。

1.3 白名單的作用

白名單里面有才讓允許通過,沒有的內(nèi)容則不允許通過。但是存在誤判的情況,比如bloomfilter中存在查詢的內(nèi)容且允許通過,但是并不是我們真正需要的那個內(nèi)容。

 1.4 白名單入門案例

public class WhiteList {
    public static void main(String[] args) {
        testGuavaWithBloomFilter();
    }
    public static void testGuavaWithBloomFilter()
    {
        //1 創(chuàng)建guava版布隆過濾器
        BloomFilter<Integer> bloomFilter = BloomFilter.create(Funnels.integerFunnel(), 100);
        //2 判斷指定的元素是否存在
        System.out.println(bloomFilter.mightContain(1));
        System.out.println(bloomFilter.mightContain(2));
        System.out.println();
        //3 講元素新增進入bloomfilter
        bloomFilter.put(1);
        bloomFilter.put(2);
        System.out.println(bloomFilter.mightContain(1));
        System.out.println(bloomFilter.mightContain(2));
    }
}

結果:

1.5 白名單+過濾器的實現(xiàn)案例

邏輯:   guava布隆過濾器插入100萬樣本數(shù)據(jù)并額外10W測試是否存在,這10w的數(shù)據(jù)在100w的數(shù)據(jù)可能存在相同的情況,存儲到相同位置。比如規(guī)則為m%3,則 1,4,7放到同一個位置槽中。

 1.5.1 代碼邏輯

1.controller

@RestController
@Slf4j
public class GuvaFilter {
    @Resource
    private GuavaBloomFilterService guavaBloomFilterService;
    @ApiOperation("guava布隆過濾器插入100萬樣本數(shù)據(jù)并額外10W測試是否存在")
    @RequestMapping(value = "/guavafilter",method = RequestMethod.GET)
    public void guavaBloomFilter()
    {
        guavaBloomFilterService.guavaBloomFilter();
    }
}

2.service

@Service
@Slf4j
public class GuavaBloomFilterService
{
    //1 定義一個常量
    public static final int _1W = 10000;
    //2 定義我們guava布隆過濾器,初始容量
    public static final int SIZE = 100 * _1W;
    //3 誤判率,它越小誤判的個數(shù)也就越少(思考,是否可以是無限?。??沒有誤判豈不是更好)
    public static double fpp = 0.01;//0.01 0.000000000000001
    //4 創(chuàng)建guava布隆過濾器
    private static BloomFilter<Integer> bloomFilter = BloomFilter.create(Funnels.integerFunnel(), SIZE,fpp);
    public void guavaBloomFilter()
    {
        //1 先讓bloomFilter加入100W白名單數(shù)據(jù)
        for (int i = 1; i <= SIZE  ; i++) {
            bloomFilter.put(i);
        }
        //2 故意取10W個不在合法范圍內(nèi)的數(shù)據(jù),來進行誤判率的演示
        ArrayList<Integer> list = new ArrayList<>(10 * _1W);
        //3 驗證
        for (int i = SIZE+1; i <= SIZE+(10 * _1W) ; i++)
        {
            if(bloomFilter.mightContain(i))
            {
                log.info("被誤判了:{}",i);
                list.add(i);
            }
        }
        log.info("誤判總數(shù)量:{}",list.size());
    }
}

3.截圖

控制臺打印日志:

1.6 bloomfilter總結

bloomfilter作用:查詢的內(nèi)容A,一定不存在,在過濾器中查詢肯定沒有;如果存在,但是存在誤判的情況,但是誤判率很小,可以忽略。

1.7 黑名單的使用

黑名單:在黑名單的存在的內(nèi)容,就不再推薦;不存在則推薦。

應用案例: 抖音等媒體的推薦內(nèi)容。

到此這篇關于redis中使用bloomfilter的白名單功能解決緩存穿透問題的文章就介紹到這了,更多相關redis bloomfilter解決緩存穿透內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Redis報錯:Could not create server TCP listening socket 127.0.0.1:6379: bind:解決方法

    Redis報錯:Could not create server TCP 

    這篇文章主要介紹了Redis報錯:Could not create server TCP listening socket 127.0.0.1:6379: bind:解決方法,是安裝與啟動Redis過程中比較常見的問題,需要的朋友可以參考下
    2023-06-06
  • 詳解三分鐘快速搭建分布式高可用的Redis集群

    詳解三分鐘快速搭建分布式高可用的Redis集群

    這篇文章主要介紹了詳解三分鐘快速搭建分布式高可用的Redis集群,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-02-02
  • redis實現(xiàn)的四種常見限流策略

    redis實現(xiàn)的四種常見限流策略

    因為在網(wǎng)站運行期間可能會因為突然的訪問量導致業(yè)務異常、也有可能遭受別人惡意攻,所以我們對網(wǎng)站要進行限流,本文主要介紹了redis四種常見限流策略,感興趣的可以了解一下
    2021-06-06
  • redis中熱key問題該如何解決

    redis中熱key問題該如何解決

    這篇文章主要給大家介紹了關于redis中熱key問題該如何解決的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用redis具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-05-05
  • redis中的bitmap你了解嗎

    redis中的bitmap你了解嗎

    這篇文章主要為大家詳細介紹了redis中的bitmap,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • Redis配置文件詳解

    Redis配置文件詳解

    這篇文章主要介紹了Redis配置文件詳解,本文詳細完整的用中文解釋了Redis配置文件中各種參數(shù)的作用和功能,需要的朋友可以參考下
    2015-04-04
  • redis集合類型_動力節(jié)點Java學院整理

    redis集合類型_動力節(jié)點Java學院整理

    這篇文章給大家介紹了redis集合類型的常用方法,感興趣的朋友參考下吧
    2017-08-08
  • 聊聊redis-dump工具安裝問題

    聊聊redis-dump工具安裝問題

    這篇文章主要介紹了redis-dump工具安裝問題,由于安裝redis-dump工具需要使用rvm?和gem工具所以要提前安裝,詳細的安裝過程本文給大家提到過,需要的朋友可以參考下
    2022-01-01
  • Linux下安裝Redis 6.0.5的實現(xiàn)

    Linux下安裝Redis 6.0.5的實現(xiàn)

    本文詳細介紹了在Linux系統(tǒng)下安裝Redis 6.0.5的步驟,包括安裝準備、編譯安裝、啟動服務、設置密碼和配置文件修改等,具有一定的參考價值,感興趣的可以了解一下
    2025-02-02
  • 關于使用IDEA的springboot框架往Redis里寫入數(shù)據(jù)亂碼問題

    關于使用IDEA的springboot框架往Redis里寫入數(shù)據(jù)亂碼問題

    這篇文章主要介紹了用IDEA的springboot框架往Redis里寫入數(shù)據(jù)亂碼問題,本文給大家分享解決方法通過圖文示例相結合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-10-10

最新評論