日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

使用 Redis 实现一个轻量级的搜索引擎

發布時間:2025/3/20 数据库 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 使用 Redis 实现一个轻量级的搜索引擎 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
今日推薦

后端接口如何提高性能?

16 個寫代碼的好習慣

為什么不推薦使用BeanUtils屬性轉換工具

盤點阿里巴巴 34 個牛逼 GitHub 項目

常見代碼重構技巧(非常實用)

作者:jasonGeng88

https://github.com/jasonGeng88/blog

場景

大家如果是做后端開發的,想必都實現過列表查詢的接口,當然有的查詢條件很簡單,一條 SQL 就搞定了,但有的查詢條件極其復雜,再加上庫表中設計的各種不合理,導致查詢接口特別難寫,然后加班什么的就不用說了(不知各位有沒有這種感受呢~)。

下面以一個例子開始,這是某購物網站的搜索條件,如果讓你實現這樣的一個搜索接口,你會如何實現?(當然你說借助搜索引擎,像 Elasticsearch 之類的,你完全可以實現。但我這里想說的是,如果要你自己實現呢?)

從上圖中可以看出,搜索總共分為6大類,每大類中又分了各個子類。這中間,各大類條件之間是取的交集,各子類中有單選、多選、以及自定義的情況,最終輸出符合條件的結果集。

好了,既然需求很明確了,我們就開始來實現。關注公眾號程序員鴻宇回復資料,可以獲取精心整理的各種編程資料。

實現1

率先登場是小A同學,他是寫 SQL 方面的“專家”。小A信心滿滿的說:“不就是一個查詢接口嗎?看著條件很多,但憑著我豐富的 SQL 經驗,這點還是難不倒我的?!?/p>

于是乎就寫出了下面這段代碼(這里以 MYSQL 為例):

select?...?from?table_1 left?join?table_2 left?join?table_3 left?join?(select?...?from?table_x?where?...)?tmp_1 ... where?... order?by?... limit?m,n

代碼在測試環境跑了一把,結果好像都匹配上了,于是準備上預發。這一上預發,問題就開始暴露出來。

預發為了盡可能的逼真線上環境,所以數據量自然而然要比測試大的多。所以這么一個復雜的 SQL,它的執行效率可想而知。測試同學果斷把小A的代碼給打了回來。

實現2

總結了小A失敗的教訓,小B開始對SQL進行了優化,先是通過了explain關鍵字進行SQL性能分析,對該加索引的地方都加上了索引。同時將一條復雜SQL拆分成了多條SQL,計算結果在程序內存中進行計算。

偽代碼如下:

$result_1?=?query('select?...?from?table_1?where?...'); $result_2?=?query('select?...?from?table_2?where?...'); $result_3?=?query('select?...?from?table_3?where?...'); ...$result?=?array_intersect($result_1,?$result_2,?$result_3,?...);

這種方案從性能上明顯比第一種要好很多,可是在功能驗收的時候,產品經理還是覺得查詢速度不夠快。

小B自己也知道,每次查詢都會向數據庫查詢多次,而且有些歷史原因,部分條件是做不到單表查詢的,所以查詢等待的時間是避免不了的。

實現3

小C從上面的方案中看到了優化的空間。他發現小B在思路上是沒問題的,將復雜條件拆分,計算各個子維度的結果集,最后將所有的子結果集進行一個匯總合并,得到最終想要的結果。

于是他突發奇想,能否事先將各個子維度的結果集給緩存起來,這要查詢的時候直接去取想要的子集,而不用每次去查庫計算。

這里小C采用 Redis 來存儲緩存數據,用它的主要原因是,它提供了多種數據結構,并且在 Redis 中進行集合的交并集操作是一件很容易的事情。

具體方案,如圖所示:

這里每個條件都事先將計算好的結果集ID存入對應的key中,選用的數據結構是集合(Set)。查詢操作包括:

  • 子類單選:直接根據條件 key,獲取對應結果集;

  • 子類多選:根據多個條件 Key,進行并集操作,獲取對應結果集;

  • 最終結果:將獲取的所有子類結果集進行交集操作,得到最終結果;

這其實就是所謂的反向索引。

這里會發現,漏了一個價格的條件。從需求中可知,價格條件是個區間,并且是無窮舉的。所以上述的這種窮舉條件的 Key-Value 方式是做不到的。這里我們采用 Redis 的另一種數據結構進行實現,有序集合(Sorted Set):

將所有商品加入 Key 為價格的有序集合中,值為商品ID,每個值對應的分數為商品價格的數值。這樣在 Redis 的有序集合中就可以通過ZRANGEBYSCORE命令,根據分數(價格)區間,獲取相應結果集。

至此,方案三的優化已全部結束,將數據的查詢與計算通過緩存的手段,進行了分離。在每次查找時,只需要簡單的查找 Redis 幾次就能得出結果。查詢速度上符合了驗收的要求。

擴展

分頁

這里你或許發現了一個嚴重的功能缺陷,列表查詢怎么能沒有分頁。是的,我們馬上來看 Redis 是如何實現分頁的。關注公眾號程序員鴻宇回復資料,可以獲取精心整理的各種編程資料。

分頁主要涉及排序,這里簡單起見,就以創建時間為例。

如圖所示:

圖中藍色部分是以創建時間為分值的商品有序集合,藍色下方的結果集即為條件計算而得的結果,通過ZINTERSTORE命令,賦結果集權重為0,商品時間結果為1,取交集而得的結果集賦予創建時間分值的新有序集合。對新結果集的操作即能得到分頁所需的各個數據:

  • 頁面總數為:ZCOUNT命令

  • 當前頁內容:ZRANGE命令

  • 若以倒序排列:ZREVRANGE命令

數據更新

關于索引數據更新的問題,有兩種方式來進行。一種是通過商品數據的修改,來即時觸發更新操作,一種是通過定時腳本來進行批量更新。

這里要注意的是,關于索引內容的更新,如果暴力的刪除 Key,再重新設置 Key。因為 Redis 中兩個操作不會是原子性進行的,所以中間可能存在空白間隙,建議采用僅移除集合中失效元素,添加新元素的方式進行。

性能優化

Redis 是內存級操作,所以單次的查詢會很快。但是如果我們的實現中會進行多次的 Redis 操作,Redis 的多次連接時間可能是不必要時間消耗。通過使用MULTI命令,開啟一個事務,將 Redis 的多次操作放在一個事務中,最后通過EXEC來進行原子性執行(注意:這里所謂的事務,只是將多個操作在一次連接中執行,如果執行過程中遇到失敗,是不會回滾的)

總結

這里只是一個采用 Redis 優化查詢搜索的一個簡單 Demo,和現有的開源搜索引擎相比,它更輕量,學習成本頁相應低些。其次,它的一些思想與開源搜索引擎是類似的,如果再加上詞語解析,也可以實現類似全文檢索的功能。

推薦文章
  • 14個項目!

  • 一款小清新的 SpringBoot+ Mybatis 前后端分離后臺管理系統項目

  • 47K Star 的SpringBoot+MyBatis+docker電商項目,附帶超詳細的文檔!

  • 寫博客能月入10K?

  • 一款基于 Spring Boot 的現代化社區(論壇/問答/社交網絡/博客)

更多項目源碼
  • 這或許是最美的Vue+Element開源后臺管理UI

  • 推薦一款高顏值的 Spring Boot 快速開發框架

  • 一款基于 Spring Boot 的現代化社區(論壇/問答/社交網絡/博客)

  • 13K點贊都基于 Vue+Spring 前后端分離管理系統ELAdmin,大愛

  • 想接私活時薪再翻一倍,建議根據這幾個開源的SpringBoot

總結

以上是生活随笔為你收集整理的使用 Redis 实现一个轻量级的搜索引擎的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 欧美日韩网站 | 日韩国产欧美在线视频 | 少妇69xx| 我的好妈妈在线观看 | 亚洲爱情岛论坛永久 | 亚洲爱| 99热在线观看 | 香蕉视频在线视频 | 韩国三级hd中文字幕有哪些 | 俄罗斯女人裸体性做爰 | 亚洲精品一区二区三区蜜桃久 | 欧美一区二区三区久久成人精品 | 狠狠操夜夜爽 | 亚洲精品一区二区三区蜜臀 | 欧美小视频在线观看 | 国产激情毛片 | 我我色综合 | 亚洲一区二区三区观看 | 黄频在线播放 | 国产美女激情视频 | aaa午夜| 精品国产一区二区三区四区 | 4438x五月天| 深爱综合网 | 男人av在线 | 午夜精产品一区二区在线观看的 | 久久99久久99| 蜜桃tv一区二区三区 | 成人视频在线观看 | 小宵虎南在线观看 | 国产精品无码久久久久高潮 | 麻豆视频在线观看 | 淫岳高潮记小说 | 精精国产xxxx视频在线播放 | 日本黄色生活片 | 波多野结衣欧美 | 亚洲网视频 | 欧美性生活免费视频 | 午夜影院男女 | 亚洲精选91 | 午夜av片| 88xx成人永久免费观看 | 欧美性福利| 欧洲av一区二区三区 | 欧美成人图区 | 欧美黑人粗大 | 精品蜜桃av| 欧美人xxx| 桃谷绘里香在线观看 | 黄视频在线播放 | 九九色播 | 国产高清小视频 | 国产精品一区二区无码对白 | 欧美日本免费 | 日韩av手机在线播放 | 五月婷婷网站 | 亚洲天天干 | 风韵少妇性饥渴推油按摩视频 | 中国无码人妻丰满熟妇啪啪软件 | 色哟哟入口国产精品 | 九九久久精品视频 | 麻豆国产91在线播放 | 山村淫强伦寡妇 | 超碰97在线免费 | 精品国产综合 | 欧美大片91 | 免费看日产一区二区三区 | 精品欧美色视频网站在线观看 | 96在线视频 | 亚洲免费在线观看av | 日韩毛片在线播放 | 亚洲欧美日本在线 | 国产精品视频一区二区在线观看 | 毛片网在线观看 | 欧美色插 | 午夜久久久久久久久久久 | 日本成人动漫在线观看 | 亚洲 精品 综合 精品 自拍 | 91色精品| 欧美精品少妇 | 亚洲人成亚洲人成在线观看 | 欧美黄色一级网站 | たちの熟人妻av一区二区 | 国产对白刺激视频 | 黄色网页免费看 | 性av网| 天天精品视频 | 欧美黄大片 | 国产一区二区三区中文字幕 | 日本综合色 | jizz性欧美15 | 精品97人妻无码中文永久在线 | 手机av免费看 | www.好了av.com| 亚洲中字幕 | 中文字幕亚洲高清 | 中日韩精品一区二区三区 | 不良视频在线观看 | 日韩在线观看视频网站 |