【Golang】golang实现简单memcache

如果有使用内存存一些简单数据的功能,可以实现下面这样的带有过期时间的内存类

内存中存储key-value,并且可以设置过期时间

package tools

import (
    "sync"
    "time"
)

// Memory struct contains *memcache.Client
type Memory struct {
    sync.Mutex

    data map[string]*data
}

type data struct {
    Data    interface{}
    Expired time.Time
}

// NewMemory create new memcache
func NewMemory() *Memory {
    return &Memory{
        data: map[string]*data{},
    }
}

// Get return cached value
func (mem *Memory) Get(key string) interface{} {
    if ret, ok := mem.data[key]; ok {
        if ret.Expired.Before(time.Now()) {
            mem.deleteKey(key)
            return nil
        }
        return ret.Data
    }
    return nil
}

// IsExist check value exists in memcache.
func (mem *Memory) IsExist(key string) bool {
    if ret, ok := mem.data[key]; ok {
        if ret.Expired.Before(time.Now()) {
            mem.deleteKey(key)
            return false
        }
        return true
    }
    return false
}

// Set cached value with key and expire time.
func (mem *Memory) Set(key string, val interface{}, timeout time.Duration) (err error) {
    mem.Lock()
    defer mem.Unlock()

    mem.data[key] = &data{
        Data:    val,
        Expired: time.Now().Add(timeout),
    }
    return nil
}

// Delete delete value in memcache.
func (mem *Memory) Delete(key string) error {
    mem.deleteKey(key)
    return nil
}

// deleteKey
func (mem *Memory) deleteKey(key string) {
    mem.Lock()
    defer mem.Unlock()
    delete(mem.data, key)
}

// clean all data
func (mem *Memory) Clean() {
    mem.Lock()
    defer mem.Unlock()
    mem.data = map[string]*data{}
}

使用方法

    mem := NewMemory()
    mem.Set("name", "livechat", time.Duration(10)*time.Second)
    time.Sleep(time.Duration(2) * time.Second)

    name := mem.Get("name")
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Golang 中,使用 `select` 语句可以轻松地实现简单的负载均衡。假设有多个服务器地址,我们可以通过 `select` 语句来选择其中一个地址进行请求: ```go package main import ( "fmt" "net/http" ) func main() { // 定义多个服务器地址 servers := []string{ "http://localhost:8080", "http://localhost:8081", "http://localhost:8082", } // 构造 http.Client client := &http.Client{} // 循环请求服务器 for { // 使用 select 语句选择服务器 select { case server := <-getServerChan(servers): // 构造请求 req, err := http.NewRequest("GET", server, nil) if err != nil { fmt.Printf("Error creating request: %s\n", err) continue } // 发送请求 resp, err := client.Do(req) if err != nil { fmt.Printf("Error sending request to %s: %s\n", server, err) continue } // 处理响应 fmt.Printf("Response from %s: %s\n", server, resp.Status) resp.Body.Close() } } } // 返回可用的服务器地址 func getServerChan(servers []string) chan string { serverChan := make(chan string) go func() { for { for _, server := range servers { serverChan <- server } } }() return serverChan } ``` 在上面的例子中,我们定义了多个服务器地址,然后通过 `select` 语句选择其中一个地址进行请求。`getServerChan` 函数会返回一个可用的服务器地址,循环中不断从该通道中获取可用的地址,然后构造请求,发送请求,处理响应。如果发送请求或处理响应出现错误,我们会记录日志并继续循环。 需要注意的是,这只是一个简单的负载均衡实现,它并没有考虑服务器的负载情况。如果需要更复杂的负载均衡策略,可以考虑使用第三方库或者自己实现算法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值