美文网首页
gobox中的simplecache和levelcache

gobox中的simplecache和levelcache

作者: ligang1109 | 来源:发表于2018-06-10 06:45 被阅读10次

今天来说下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会存储在单机磁盘上,不是分布式的。

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

相关文章

  • gobox中的simplecache和levelcache

    今天来说下gobox中的simplecache和levelcache simplecache simplecach...

  • gobox中的color和crypto

    今天来说下gobox中的color和crypto两个box。 color color的主要作用是为在终端中输出的信...

  • gobox中的shardmap

    今天来说下gobox中的shardmap。 golang中的map使用简单,但并发写入时,如果不加锁,会导致pan...

  • gobox中的httpclient

    今天来说下使用gobox中httpclient,这个包就相当于命令行的curl工具,用于发起http请求。 重要的...

  • gobox中的编解码和执行shell命令

    今天来说下gobox中的encoding和shell两个box。 encoding encoding的主要作用是完...

  • gobox中的分页操作

    今天来说下使用gobox中的分页操作 说明 分页也是我们开发时的一个常见需求,gobox中提供了page包做这个事...

  • gobox中的log操作

    今天来说下使用gobox中的log操作 log级别定义 重要的interface IWriter 定义消息写入到哪...

  • gobox中的异常定义和杂项工具

    今天来说下gobox中的异常定义和杂项工具。 exception 很多语言提供了异常机制,但是go没有,相似的能力...

  • gobox中redis操作

    今天来说下使用gobox中redis操作相关 说明 本包的driver部分使用了redigo:https://gi...

  • gobox中mysql操作

    今天来说下使用gobox中mysql操作相关 说明 本包的driver部分使用了go-sql-driver:htt...

网友评论

      本文标题:gobox中的simplecache和levelcache

      本文链接:https://www.haomeiwen.com/subject/opxfeftx.html