關(guān)于Redis的討論,其實在現(xiàn)在的后臺開發(fā)中已經(jīng)是個老生常談的問題,基本上也是后端開發(fā)面試的基本考察點。其中 Redis的背景介紹和細(xì)節(jié)說明在這里就不贅述。不管怎么介紹,核心在于Redis是一個基于內(nèi)存的key-value的多數(shù)據(jù)結(jié)構(gòu)存儲,并可以提供持久化服務(wù)?;趦?nèi)存的特性決定了Redis天然適合高并發(fā)的數(shù)據(jù)讀寫緩存優(yōu)化,同時也帶來了內(nèi)存開銷過大的問題。所以在一些特定情景下,Redis是一把無往不利的大殺器,值得深入學(xué)習(xí)。
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)
}
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接