0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

GeminiDB 新特性:讓 Redis 廣告頻控愛不釋手的 exHASH

jf_21561199 ? 來源:jf_21561199 ? 作者:jf_21561199 ? 2024-04-08 18:26 ? 次閱讀

exHash 類型是一種支持 Field 過期的新型數(shù)據(jù)類型,它在原先的 Hash 類型基礎(chǔ)上進(jìn)行了擴(kuò)展:在支持 Hash 類型的通用功能以外,exHash 類型還支持為 Field 設(shè)置過期時(shí)間和版本,增強(qiáng)了數(shù)據(jù)結(jié)構(gòu)的靈活性,從而簡(jiǎn)化了很多復(fù)雜場(chǎng)景下的業(yè)務(wù)開發(fā)工作。

本文以兩種常見的場(chǎng)景(頻控場(chǎng)景 &購物車)為例,通過使用 GeminiDB Redis 接口中的 exHash 類命令來實(shí)現(xiàn)復(fù)雜的業(yè)務(wù),簡(jiǎn)化開發(fā)難度。

一、exHash 命令使用簡(jiǎn)介

wKgaomYELouAXiH4AAqJUmc8_5k47.webp

命令語法定義如下:

大寫關(guān)鍵字:命令關(guān)鍵字。

斜體:變量。

[options]:可選參數(shù),不在括號(hào)中的參數(shù)為必選。

A|B:該組參數(shù)互斥,請(qǐng)進(jìn)行二選一或多選一。

...:前面的內(nèi)容可重復(fù)。

二、應(yīng)用場(chǎng)景

1.頻控場(chǎng)景

頻控指的是對(duì)用戶在一定時(shí)間內(nèi)(例如一天、一周、一個(gè)月)進(jìn)行某種操作的次數(shù)進(jìn)行限制,可以控制特定廣告或信息在一定時(shí)間內(nèi)在特定平臺(tái)上的展示次數(shù),以避免過度曝光和廣告疲勞,同時(shí)優(yōu)化廣告效果和用戶體驗(yàn);對(duì)于廣告來說,也可以提高廣告的效果和轉(zhuǎn)化率。此外,頻控還可以避免惡意行為,如刷流量、刷評(píng)論、刷點(diǎn)贊等。

頻控的 3 個(gè)要素包含用戶 ID、廣告 ID、觸發(fā)次數(shù);以用戶 ID 為 key,廣告 ID 為 field,指定時(shí)間內(nèi)的觸發(fā)次數(shù)為 value,恰好構(gòu)成頻控的三要素。先配置好各個(gè)廣告的指定頻控策略,如下圖所示即可根據(jù)如下的方式來實(shí)現(xiàn)頻控:

wKgZomYELouAD_MjAAGxpe5msA034.webp

最左邊通過 Hash 類型來實(shí)現(xiàn),通過 expire 命令設(shè)置 User_1 的過期時(shí)間為一天,每推送一次通過 hincrby 來增加指定廣告的推送次數(shù),每次推送指定廣告前在一天內(nèi)的推送次數(shù)則可以通過 hget 獲取進(jìn)行判斷,一天后該用戶的數(shù)據(jù)自動(dòng)過期無需手動(dòng)清理,這樣便可以簡(jiǎn)單地實(shí)現(xiàn)頻控。但這個(gè)方案的缺點(diǎn)在于對(duì)于每個(gè)用戶(即每個(gè) key)只能設(shè)置一個(gè)過期時(shí)間,無法做到例如 8 小時(shí) 3 次這樣指定時(shí)間段內(nèi)的靈活的頻控策略。

為了做到對(duì)每個(gè)廣告都配置指定時(shí)間段內(nèi)的靈活頻控,如中間圖所示可以通過將時(shí)間戳拼接在 value 里的方式用 Hash 類型來實(shí)現(xiàn),但這種方案無疑是增加了業(yè)務(wù)側(cè)開發(fā)的工作量。

如最右圖所示,支持給 field 設(shè)置過期時(shí)間的 exHash 類型可以很完美地解決 Hash 類型面對(duì)頻控場(chǎng)景的缺點(diǎn)。由于 Field 支持過期時(shí)間設(shè)置,那么該場(chǎng)景下,平臺(tái)可以給每個(gè)廣告都配置不同時(shí)間段內(nèi)的頻次要求,假設(shè)此時(shí)給 AD_2 配置的頻控策略為 8 小時(shí)內(nèi) 2 次,那么如圖所示在下一次再準(zhǔn)備給 User_1 推送 AD_2 廣告前,先通過 exhget User_1 AD_2 命令獲取到了該值已經(jīng)是 2 時(shí),便可以判斷出此時(shí)根據(jù)平臺(tái)頻控策略,不應(yīng)該再給 User_1 推送 AD_2 廣告了。而當(dāng) 8 小時(shí)一過,User_1 的 AD_2 這個(gè) field 過期后,exhget 無法再獲取到這個(gè) field 的信息,則可以繼續(xù)給 User_1 推送 AD_2 廣告了。

2.購物車場(chǎng)景

最近雙十一期間,相信很多同學(xué)購物車?yán)锒继顫M了各種想要清空的寶貝,這里就以購物車場(chǎng)景為例介紹該場(chǎng)景的幾種不同 Redis 類型的實(shí)現(xiàn),并比較這幾種實(shí)現(xiàn)方案的優(yōu)缺點(diǎn)。

1)基于 String 實(shí)現(xiàn)購物車功能

如圖所示基于 String 可以輕松地實(shí)現(xiàn)各個(gè)用戶的購物車功能,該方案需要將用戶 ID 與商品 ID 進(jìn)行拼接作為 key,例如 User_1#Earphones_1,key 對(duì)應(yīng)的 value 為購物車中用戶準(zhǔn)備購買的數(shù)量,其中可能有部分商品為限時(shí)特購,所以有過期時(shí)間,為 key 對(duì)應(yīng)的過期時(shí)間。

wKgaomYELoyAIiDeAABrXRocggY85.webp

涉及命令如下:

wKgZomYELoyAGUgUAAD6XRrxoXA79.webp

該方案會(huì)存在如下問題:

額外拼接增加編、解碼開發(fā)工作量

某個(gè)用戶獲取自己的購物車清單時(shí)還需要通過 scan 命令前綴匹配掃描所有 key,并通過 get 命令去獲取對(duì)應(yīng)的值。

想要直接獲取清單長度時(shí),仍然需要遍歷整個(gè)前綴 key 的數(shù)目,方法復(fù)雜。

存在大量重復(fù)的用戶名前綴,浪費(fèi)存儲(chǔ)空間。

2)基于 Hash 實(shí)現(xiàn)購物車功能

可以根據(jù)如圖所示的 Hash 類型來實(shí)現(xiàn)購物車的管理,用戶 ID 作為 key,商品 ID 作為 field,value 為購物車中對(duì)應(yīng)商品的數(shù)量。其中對(duì)于部分限時(shí)特購的商品,其過期時(shí)間通過拼接的方式放到 field 對(duì)應(yīng)的 value 里。

wKgaomYELo2AcvMXAABWc45KMjU39.webp

涉及命令如下:

wKgZomYELo2AQ2oxAAEoVPDwuJk41.webp

該方案相對(duì)于 String 類型的方案有了不少優(yōu)化:

獲取某個(gè)用戶購物車中的所有商品清單僅需要一個(gè) hgetall 命令即可

獲取某個(gè)用戶的清單長度時(shí)直接 hlen 獲取即可

不存在大量重復(fù)的用戶名前綴問題

然而該方案仍存在一個(gè)明顯的缺點(diǎn),即對(duì)于部分限時(shí)特購的商品處理起來復(fù)雜:對(duì)于 User_1 的 Keyboard_1 商品,如果要再加一個(gè)數(shù)量,不能直接使用 hincrby,而是需要先 hget 獲取 Keyboard_1 商品的值并解碼,再加上指定的數(shù)量再編碼后 hset 對(duì)應(yīng)的值。

3)基于 exHash 實(shí)現(xiàn)購物車功能

根據(jù)如圖所示的 exHash 類型來實(shí)現(xiàn)購物車的管理,同 Hash 類型一樣,用戶 ID 作為 key,商品 ID 作為 field,value 為購物車中對(duì)應(yīng)商品的數(shù)量。其中對(duì)于部分限時(shí)特購的商品,由于 exHash 類型可以為 Field 設(shè)置過期時(shí)間,其過期時(shí)間可通過 hset 命令直接設(shè)置。

wKgaomYELo6AXUclAABkKnHz51E91.webp

涉及命令如下:

wKgZomYELo-ANXV7AAFeIa9cFtk63.webp

該方案相對(duì)于 Hash 類型的優(yōu)化主要體現(xiàn)在可以直接為各 field 設(shè)置過期時(shí)間,使業(yè)務(wù)側(cè)使用起來簡(jiǎn)單又高效。可以看到 exHash 類型相關(guān)的命令和 Hash 類型是類似的,使用起來學(xué)習(xí)成本很低,業(yè)務(wù)側(cè)改造成本相對(duì)也比較低。

wKgaomYELo-ATHolAAJmte8PcIQ67.webp

圖 1.1 華為商城購物車中,用戶 ID、商品 ID、商品數(shù)量及 exhash 類型命令的使用。

三、總結(jié)

本文介紹了 GeminiDB Redis 接口的 exHash 類型的特性、使用方法及應(yīng)用場(chǎng)景。為客戶提供了一種語法與原生 Redis Hash 類型類似、和 Hash 類型的使用相互隔離、支持給 Field 單獨(dú)設(shè)置過期時(shí)間和版本的 exHash 類型作為各種復(fù)雜場(chǎng)景的解決方案。未來,GeminiDB Redis 接口將持續(xù)致力于開發(fā)更多好用的企業(yè)級(jí)特性,幫助客戶輕松運(yùn)維,高效開發(fā)。

如果你的業(yè)務(wù)需要一款穩(wěn)定可靠的 KV 數(shù)據(jù)庫,可以試試 GeminiDB Redis 接口。

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Gemini
    +關(guān)注

    關(guān)注

    0

    文章

    55

    瀏覽量

    7607
  • Redis
    +關(guān)注

    關(guān)注

    0

    文章

    376

    瀏覽量

    10898
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    Redis緩存與Memcached的比較

    關(guān)鍵特性和差異: 1. 數(shù)據(jù)存儲(chǔ) Redis: Redis是一個(gè)開源的鍵值存儲(chǔ),支持多種數(shù)據(jù)結(jié)構(gòu),如字符串、列表、集合、有序集合、散列、位圖、超日志和地理空間索引。 它支持持久化,可以將內(nèi)存中的數(shù)據(jù)保存到磁盤,支持RDB(快照)
    的頭像 發(fā)表于 12-18 09:33 ?182次閱讀

    RoboMaster S1/EP SDK 在 Linux 下安裝及使用

    的,不到3000塊。孩子玩起來還愛不釋手,還能順便學(xué)編程。 在 Rust 群里得知有一個(gè) Dora-rs (https://dora-rs.ai/) 框架,而其作者也是用 Robomaster S1
    的頭像 發(fā)表于 12-04 18:23 ?330次閱讀
    RoboMaster S1/EP SDK 在 Linux 下安裝及使用

    福特CEO認(rèn)可中國電動(dòng)汽車企業(yè)領(lǐng)先地位

    愛不釋手,甚至不愿嘗試其他車型。法利還透露,在之前的訪華行程中,他特別關(guān)注了小米汽車,并親自安排將一輛小米SU7從上??者\(yùn)至芝加哥進(jìn)行深入研究。
    的頭像 發(fā)表于 10-23 14:35 ?449次閱讀

    12V化妝鏡觸摸燈三級(jí)觸摸調(diào)光方案開發(fā)

    對(duì)化妝來說光線實(shí)在重要,在非合適的光源下打過來光下看自己,我們所看到的輪廓跟現(xiàn)實(shí)情況是有偏差的。換句話來說,要想化出完美的妝容,妹子們都需要一束來自鏡子的光。 好用到愛不釋手!鏡面兩個(gè)按鈕,操作
    的頭像 發(fā)表于 10-22 15:03 ?239次閱讀

    玄派玄機(jī)星2024游戲本的簡(jiǎn)單介紹

    玄派玄機(jī)星2024,一款擁有獨(dú)特個(gè)性且性價(jià)比優(yōu)秀的游戲本,它采用第二代AMD AI PC 處理器 —— 銳龍7 8845HS移動(dòng)處理器,搭配AMD Radeon RX 7600M XT獨(dú)顯,強(qiáng)大的算力和優(yōu)秀的畫面表現(xiàn)力,讓你在游戲中愛不釋手
    的頭像 發(fā)表于 09-19 10:52 ?693次閱讀

    【「OpenHarmony開發(fā)與實(shí)踐 | 基于紅莓RK2206開發(fā)板」閱讀體驗(yàn)】+初體驗(yàn)2連發(fā)發(fā)

    劃分得恰到好處,就像精心布置的迷宮,人在閱讀的過程中既能輕松找到出路,又能享受到探索的樂趣! 而內(nèi)容呢,更是愛不釋手!作者用他那簡(jiǎn)潔明了的語言,把復(fù)雜的概念和理論描述的非常清楚,真的是太厲害
    發(fā)表于 09-18 18:01

    分立器件在智能美妝化妝鏡上的應(yīng)用

    愛美之心,人皆有之。隨著智能時(shí)代來臨,帶點(diǎn)AI的智能化妝鏡更有市場(chǎng)競(jìng)爭(zhēng)力。近日,在某國外網(wǎng)站上,賣火了的產(chǎn)品,它集補(bǔ)光、高清顯示和AI功能于一身,美妝神器成為很多博主愛不釋手的寶貝。它通常會(huì)采用
    的頭像 發(fā)表于 08-05 10:06 ?319次閱讀
    分立器件在智能美妝化妝鏡上的應(yīng)用

    高效充電!你被這條快充電源線硬控了嗎?

    需求這條電源線都能高效滿足愛不釋手!快讓我們一起揭開這條橙色USBType-C快充電源線的神秘面紗吧!產(chǎn)品亮點(diǎn)高效充電快人一步MINIWARE新推出的橙色快充
    的頭像 發(fā)表于 06-06 08:02 ?600次閱讀
    高效充電!你被這條快充電源線硬控了嗎?

    華為云多模數(shù)據(jù)庫 GeminiDB 架構(gòu)與應(yīng)用實(shí)踐直播問答實(shí)錄

    龍通過直播(鏈接見文末)的方式,分享了《華為云多模數(shù)據(jù)庫 GeminiDB 的技術(shù)架構(gòu)及應(yīng)用實(shí)踐》,對(duì) GeminiDB 的技術(shù)特性、架構(gòu)優(yōu)勢(shì)等進(jìn)行了全方位解讀。整場(chǎng)直播干貨滿滿,
    的頭像 發(fā)表于 04-08 18:25 ?1185次閱讀

    華為云 GeminiDB 發(fā)布新版本,全面支持 Redis 6.2

    華為云 GeminiDB 是一款兼容 Redis 協(xié)議的彈性 KV(Key-Value)數(shù)據(jù)庫,支持遠(yuǎn)超內(nèi)存的容量和極致的性能,可支撐用戶平滑遷移,在廣告、游戲、電商等行業(yè)有著廣泛的應(yīng)用。 今年 3
    的頭像 發(fā)表于 04-08 18:22 ?1152次閱讀
    華為云 <b class='flag-5'>GeminiDB</b> 發(fā)布新版本,全面支持 <b class='flag-5'>Redis</b> 6.2

    Redis開源版與Redis企業(yè)版,怎么選用?

    點(diǎn)擊“藍(lán)字”關(guān)注我們數(shù)以千計(jì)的企業(yè)和數(shù)以百萬計(jì)的開發(fā)人員Redis開源版來構(gòu)建應(yīng)用程序。但隨著用戶數(shù)量、數(shù)據(jù)量和地區(qū)性的增加,成本、可擴(kuò)展性、運(yùn)營和可用性等問題也隨之而來。Redis企業(yè)版
    的頭像 發(fā)表于 04-04 08:04 ?1153次閱讀
    <b class='flag-5'>Redis</b>開源版與<b class='flag-5'>Redis</b>企業(yè)版,怎么選用?

    GaussDB(for Redis) 特性揭秘:多租戶管理

    華為云 GaussDB(for Redis)持續(xù)完善企業(yè)級(jí)增強(qiáng)特性,是名副其實(shí)的 "Redis Plus" ,其中很經(jīng)典的企業(yè)級(jí)特性是 多租戶能力 ,支持添加只讀賬號(hào)、讀寫賬號(hào),且具備
    的頭像 發(fā)表于 03-28 22:06 ?766次閱讀
    GaussDB(for <b class='flag-5'>Redis</b>) <b class='flag-5'>特性</b>揭秘:多租戶管理

    GaussDB(for Redis) 特性揭秘:大 key 治理

    運(yùn)行過程中悄悄產(chǎn)生的,人防不勝防。因此,一款可隨時(shí)在線診斷,且能主動(dòng)預(yù)警,防患于未然的 Redis 服務(wù)產(chǎn)品顯得尤為重要。 ? 作為由華為云精心打造的企業(yè)級(jí) Redis,GaussDB
    的頭像 發(fā)表于 03-28 22:06 ?683次閱讀
    GaussDB(for <b class='flag-5'>Redis</b>) <b class='flag-5'>特性</b>揭秘:大 key 治理

    新版 Redis 不再“開源”,對(duì)使用者都有哪些影響?

    2024 年 3 月 20 日,Redis Labs 宣布從 Redis 7.4 開始,將原先比較寬松的 BSD 源碼使用協(xié)議修改為 RSAv2和 SSPLv1協(xié)議。該變化意味著 Redis
    的頭像 發(fā)表于 03-27 22:30 ?524次閱讀
    新版 <b class='flag-5'>Redis</b> 不再“開源”,對(duì)使用者都有哪些影響?

    MongoDB和Redis的技術(shù)特性

    Redis作為一個(gè)高性能的內(nèi)存數(shù)據(jù)存儲(chǔ)系統(tǒng),能夠提供快速的緩存機(jī)制,從而幫助應(yīng)用承受高并發(fā)請(qǐng)求,顯著提高系統(tǒng)響應(yīng)速度和吞吐量。這與國內(nèi)互聯(lián)網(wǎng)公司推崇的快速迭代和高用戶并發(fā)量的特點(diǎn)非常契合。
    的頭像 發(fā)表于 02-01 11:42 ?532次閱讀
    MongoDB和<b class='flag-5'>Redis</b>的技術(shù)<b class='flag-5'>特性</b>