golang操作redis主要有兩個庫,go-redis和redigo。兩者操作都比較簡單,區別上redigo更像一個client執行各種操作都是通過Do函數去做的,redis-go對函數的封裝更好,相比之下redigo操作redis顯得有些繁瑣。但是官方更推薦redigo,所以項目中我使用了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()
//寫入數據
_, 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并轉成字符串
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")
}
//設置key過期時間
_, err = c.Do("SET", "mykey", "superWang", "EX", "5")
if err != nil {
fmt.Println("redis set failed:", err)
}
//創建key時設置5s過期
_, err := c.Do("SET", "go_key:ex", "redigo", "EX", 5)
if err != nil {
logger.Runtime().Info(map[string]interface{}{"error": err}, "error while setting")
}
//對已有key設置5s過期時間
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")
}
}