代碼地址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如下:

網(wǎng)友評論

    <label id="0edu1"><legend id="0edu1"></legend></label>

    <pre id="0edu1"><noframes id="0edu1"><rt id="0edu1"></rt>