代碼地址github:cache

花了一天時(shí)間看了下實(shí)驗(yàn)樓的cache組件,使用golang編寫的,收獲還是蠻多的,緩存組件的設(shè)計(jì)其實(shí)挺簡單的,主要思路或者設(shè)計(jì)點(diǎn)如下:

  • 全局struct對象:用來做緩存(基于該struct實(shí)現(xiàn)增刪改查基本操作)

  • 定時(shí)gc功能(其實(shí)就是定時(shí)刪除struct對象中過期的緩存對):剛好用上golang的ticker外加channel控制實(shí)現(xiàn)

  • 支持緩存寫文件及從文件讀緩存:其實(shí)就是將這里的key-value數(shù)據(jù)通過gob模塊進(jìn)行一次編解碼操作

  • 并發(fā)讀寫:上鎖(golang支持讀寫鎖,一般使用時(shí)在被操作的struct對象里面聲明相應(yīng)的鎖,即sync.RWMutex,操作之前先上鎖,之后解鎖即可)

其實(shí)大概就是這么多,下面來分解下:

1、cache組件

要保存數(shù)據(jù)到緩存(即內(nèi)存中),先要設(shè)計(jì)數(shù)據(jù)結(jié)構(gòu),cache一般都有過期時(shí)間,抽象的struct如下:

  1. 網(wǎng)友評論