golang操作redis主要有兩個(gè)庫(kù),go-redis和redigo。兩者操作都比較簡(jiǎn)單,區(qū)別上redigo更像一個(gè)client執(zhí)行各種操作都是通過(guò)Do函數(shù)去做的,redis-go對(duì)函數(shù)的封裝更好,相比之下redigo操作redis顯得有些繁瑣。但是官方更推薦redigo,所以項(xiàng)目中我使用了redigo。
package redisclient
import (
"fmt"
redigo "github.com/garyburd/redigo/redis"
)
var pool *redigo.Pool
func init() {
redis_host := "127.0.0.1"
redis_port := 6379
pool_size := 20
pool = redigo.NewPool(func() (redigo.Conn, error) {
c, err := redigo.Dial("tcp", fmt.Sprintf("%s:%d", redis_host, redis_port))
if err != nil {
return nil, err
}
return c, nil
}, pool_size)
}
func Get() redigo.Conn {
return pool.Get()
}
package main
import (
"redisclient"
"logger"
"github.com/garyburd/redigo/redis"
)
func main() {
c := redisclient.Get()
//記得銷毀本次鏈連接
defer c.Close()
//寫入數(shù)據(jù)
_, err := c.Do("SET", "go_key", "redigo")
if err != nil {
logger.Runtime().Info(map[string]interface{}{"error": err}, "error while setting")
}
//判斷key是否存在
is_key_exit, err := redis.Bool(c.Do("EXISTS", "go_key"))
if err != nil {
logger.Runtime().Info(map[string]interface{}{"error": err}, "error while existing")
}
//獲取value并轉(zhuǎn)成字符串
account_balance, err := redis.String(c.Do("GET", "go_key"))
if err != nil {
logger.Runtime().Info(map[string]interface{}{"error": err}, "error while getting")
}
//刪除key
_, err = c.Do("DEL", "go_key")
if err != nil {
logger.Runtime().Info(map[string]interface{}{"error": err}, "error while deleting")
}
//設(shè)置key過(guò)期時(shí)間
_, err = c.Do("SET", "mykey", "superWang", "EX", "5")
if err != nil {
fmt.Println("redis set failed:", err)
}
//創(chuàng)建key時(shí)設(shè)置5s過(guò)期
_, err := c.Do("SET", "go_key:ex", "redigo", "EX", 5)
if err != nil {
logger.Runtime().Info(map[string]interface{}{"error": err}, "error while setting")
}
//對(duì)已有key設(shè)置5s過(guò)期時(shí)間
n, err := rs.Do("EXPIRE", "go_key", 5)
if err != nil {
logger.Runtime().Info(map[string]interface{}{"error": err}, "error while setting")
} else if n != int64(1) {
fmt.Println("failed")
}
}