gobox中的simplecache和levelcache

今天来说下gobox中的simplecache和levelcache

simplecache

simplecache提供了一个简单的内存kv

用法示例

package main

import (
    "github.com/goinbox/crypto"
    "github.com/goinbox/simplecache"

    "fmt"
    "time"
    "strconv"
)

func main() {
    sc := simplecache.NewSimpleCache()

    for i := 0; i < 10000; i++ {
        key := crypto.Md5String([]byte(strconv.Itoa(i)))
        sc.Set(key, i, 3*time.Second)

        v, ok := sc.Get(key)
        if !ok || v != i {
            fmt.Println(v, ok)
        }
    }

    time.Sleep(4 * time.Second)

    allKeysExpires := true
    for i := 0; i < 10000; i++ {
        key := crypto.Md5String([]byte(strconv.Itoa(i)))

        v, ok := sc.Get(key)
        if ok || v == i {
            fmt.Println(v, ok)
            allKeysExpires = false
        }
    }

    if allKeysExpires {
        fmt.Println("all keys have expired")
    }
}

输出效果示例

all keys have expired

特别说明

  1. 在使用时,如果set的值是引用类型,那么改变引用的对象的值时,cache中的内容也会改变,这一点要特别注意。
  2. 因为是内存cache,所以进程退出则cache内容全部丢失。

levelcache

levelcache以leveldb为底层存储引擎,提供了一个单机落盘的kv

用法示例

package main

import (
    "github.com/goinbox/levelcache"

    "fmt"
    "time"
)

func main() {
    cache, _ := levelcache.NewCache("/tmp/levelcache_test", 5*time.Second)

    key := []byte("k1")
    value := []byte("v1")

    cache.Set(key, value, 3)

    value, _ = cache.Get(key)
    sv := string(value)
    fmt.Println(sv)
    if sv != "v1" {
        fmt.Println("set get error")
    }

    time.Sleep(4 * time.Second)

    v, err := cache.Get(key)
    sv = string(v)
    fmt.Println(sv, err)
}

输出效果示例

v1
 <nil>

特别说明

cache会存储在单机磁盘上,不是分布式的。

欢迎大家使用,使用中有遇到问题随时反馈,我们会尽快响应,谢谢!

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,991评论 19 139
  • 查询引擎 一、Phoenix 贡献者::Salesforce 简介:这是一个Java中间层,可以让开发者在Apac...
    秋天的程序员阅读 1,198评论 0 4
  • 夜 现已是深夜,指针早已悄然跨过了十二点,可是没有任何提示的声音,我记得小时候的木钟,也就是上发条的那种,每到十二...
    会发光的叮叮猫儿阅读 244评论 0 0
  • 一,Jenkins简介 Jenkins就是一个自动打包的工具,方便给测试打包,开发每次需改了代码直接上传到git/...
    孟小凡阅读 1,960评论 0 0
  • 电影《七月与安生》中的两个小姐妹让我想起我和闺蜜的童年时光。七岁那年搬家,认识了新邻居,比我略大的一个小姑娘。我们...
    风中的雏菊阅读 282评论 1 3