使用go来操作redis的方法示例
程序员文章站
2023-10-31 09:30:04
redis简单介绍
简介
关于redis的讨论,其实在现在的后台开发中已经是个老生常谈的问题,基本上也是后端开发面试的基本考察点。其中 redis的背景介绍和细节说明在...
redis简单介绍
简介
关于redis的讨论,其实在现在的后台开发中已经是个老生常谈的问题,基本上也是后端开发面试的基本考察点。其中 redis的背景介绍和细节说明在这里就不赘述。不管怎么介绍,核心在于redis是一个基于内存的key-value的多数据结构存储,并可以提供持久化服务。基于内存的特性决定了redis天然适合高并发的数据读写缓存优化,同时也带来了内存开销过大的问题。所以在一些特定情景下,redis是一把无往不利的大杀器,值得深入学习。
安装redis, 运行如下go代码:
package main import ( "time" "fmt" "github.com/go-redis/redis" ) var client *redis.client func init() { client = redis.newclient(&redis.options{ addr: "127.0.0.1:6379", poolsize: 1000, readtimeout: time.millisecond * time.duration(100), writetimeout: time.millisecond * time.duration(100), idletimeout: time.second * time.duration(60), }) _, err := client.ping().result() if err != nil { panic("init redis error") } else { fmt.println("init redis ok") } } func get(key string) (string, bool) { r, err := client.get(key).result() if err != nil { return "", false } return r, true } func set(key string, val string, exptime int32) { client.set(key, val, time.duration(exptime) * time.second) } func main() { set("name", "x", 100) s, b := get("name") fmt.println(s, b) }
结果:
init redis ok
x true
过期时间是100s, 过期后,get无法获取信息, 返回了nil
简单, 不多说。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接