掃二維碼與項(xiàng)目經(jīng)理溝通
我們?cè)谖⑿派?4小時(shí)期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營(yíng)咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
布隆過濾器(Bloom Filter)是一種空間效率極高的概率型數(shù)據(jù)結(jié)構(gòu),用于判斷一個(gè)元素是否在一個(gè)集合中。它基于位數(shù)組和多個(gè)哈希函數(shù)的原理,可以高效地進(jìn)行元素的查詢,而且占用的空間相對(duì)較小,如下圖所示:

創(chuàng)新互聯(lián)建站專注于羅田企業(yè)網(wǎng)站建設(shè),自適應(yīng)網(wǎng)站建設(shè),商城系統(tǒng)網(wǎng)站開發(fā)。羅田網(wǎng)站建設(shè)公司,為羅田等地區(qū)提供建站服務(wù)。全流程定制網(wǎng)站開發(fā),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)建站專業(yè)和態(tài)度為您提供的服務(wù)
根據(jù) key 值計(jì)算出它的存儲(chǔ)位置,然后將此位置標(biāo)識(shí)全部標(biāo)識(shí)為 1(未存放數(shù)據(jù)的位置全部為 0),查詢時(shí)也是查詢對(duì)應(yīng)的位置是否全部為 1,如果全部為 1,則說明數(shù)據(jù)是可能存在的,否則一定不存在。
也就是說,如果布隆過濾器說一個(gè)元素不在集合中,那么它一定不在這個(gè)集合中;但如果它說一個(gè)元素在集合中,則有可能是不存在的(存在誤差)。
布隆過濾器的具體執(zhí)行步驟如下:
布隆過濾器的主要使用場(chǎng)景有以下幾個(gè):
在 Redis 中不能直接使用布隆過濾器,但我們可以通過 Redis 4.0 版本之后提供的 modules (擴(kuò)展模塊) 的方式引入,它的實(shí)現(xiàn)步驟如下。
“
git clone https://github.com/RedisLabsModules/redisbloom.git
cd redisbloom
make # 編譯redisbloom
”
編譯正常執(zhí)行完,會(huì)在根目錄生成一個(gè) redisbloom.so 文件。
重新啟動(dòng) Redis 服務(wù),并指定啟動(dòng) RedisBloom 插件,具體命令如下:
“
redis-server redis.conf --loadmodule ./src/modules/RedisBloom-master/redisbloom.so
”
創(chuàng)建一個(gè)布隆過濾器,并設(shè)置期望插入的元素?cái)?shù)量和誤差率,在 Redis 客戶端中輸入以下命令:
“
BF.RESERVE my_bloom_filter 0.01 100000
”
在 Redis 客戶端中輸入以下命令:
“
BF.ADD my_bloom_filter leige
”
在 Redis 客戶端中輸入以下命令:
“
BF.EXISTS my_bloom_filter leige
”
以上我們介紹了什么是布隆過濾器?它的使用場(chǎng)景和執(zhí)行流程,以及在 Redis 中它的使用,那么問題來(lái)了,在日常開發(fā)中,也就是在 Java 開發(fā)中,我們又將如何操作布隆過濾器呢?

我們?cè)谖⑿派?4小時(shí)期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營(yíng)咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流