代碼地址github:cache
花了一天時間看了下實驗樓的cache組件,使用golang編寫的,收獲還是蠻多的,緩存組件的設(shè)計其實挺簡單的,主要思路或者設(shè)計點如下:
全局struct對象:用來做緩存(基于該struct實現(xiàn)增刪改查基本操作)
定時gc功能(其實就是定時刪除struct對象中過期的緩存對):剛好用上golang的ticker外加channel控制實現(xiàn)
支持緩存寫文件及從文件讀緩存:其實就是將這里的key-value數(shù)據(jù)通過gob模塊進(jìn)行一次編解碼操作
并發(fā)讀寫:上鎖(golang支持讀寫鎖,一般使用時在被操作的struct對象里面聲明相應(yīng)的鎖,即sync.RWMutex,操作之前先上鎖,之后解鎖即可)
其實大概就是這么多,下面來分解下:
1、cache組件
要保存數(shù)據(jù)到緩存(即內(nèi)存中),先要設(shè)計數(shù)據(jù)結(jié)構(gòu),cache一般都有過期時間,抽象的struct如下: