前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >在Go语言中基础的Redis操作

在Go语言中基础的Redis操作

作者头像
程序员同行者
发布2019-02-22 09:44:33
8330
发布2019-02-22 09:44:33
举报
文章被收录于专栏:程序员同行者
在Go语言中基础的Redis操作

需要先安装redigo

代码语言:javascript
复制
go get "github.com/garyburd/redigo/redis"

Go语言Redis客户端的简单示例

连接池 POOL

为了和redis建立连接,需要创建一个redis.Pool的对象

代码语言:javascript
复制
func newPool() *redis.Pool {
    return &redis.Pool{
        MaxIdle:   10,
        MaxActive: 12000,
        Dial: func() (redis.Conn, error) {
            c, err := redis.Dial("tcp", ":6379")
            if err != nil {
                panic(err)
            }
            return c, err
        },
    }
}
测试连接 PING

如果想测试是否连接成功,可以使用 PING命令

代码语言:javascript
复制
func ping(c redis.Conn) error {
    pong, err := c.Do("PING")
    if err != nil {
        return err
    }

    s, err := redis.String(pong, err)
    if err != nil {
        return err
    }
    fmt.Printf("PING Response = %s\n", s)
    return nil
}

SET

代码语言:javascript
复制
func set(c redis.Conn) error {
    _, err := c.Do("SET", "Favorite Movie", "Repo Man")
    if err != nil {
        return err
    }
    _, err = c.Do("SET", "Release Year", 1984)
    if err != nil {
        return err
    }
    return nil
}

GET

代码语言:javascript
复制
func get(c redis.Conn) error {
    key := "Favorite Movie"
    s, err := redis.String(c.Do("GET", key))
    if err != nil {
        return err
    }
    fmt.Printf("%s = %s\n", key, s)

    key = "Release Year"
    i, err := redis.Int(c.Do("GET", key))
    if err != nil {
        return err
    }
    fmt.Printf("%s = %d\n", key, i)

    key = "Nonexistent Key"
    s, err = redis.String(c.Do("GET", key))
    if err == redis.ErrNil {
        fmt.Printf("%s does not exist\n", key)
    } else if err != nil {
        return err
    } else {
        fmt.Printf("%s = %s\n", key, s)
    }
    return nil
}

SET STRUCT

代码语言:javascript
复制
func setStruct(c redis.Conn) error {
    const objectPrefix string = "user:"
    user := User{
        Username:  "coderminer.com",
        MobileID:  "12345678941",
        Email:     "kevin@163.com",
        FirstName: "coderminer.com",
        LastName:  "coderminer.com",
    }

    json, err := json.Marshal(user)
    if err != nil {
        return err
    }

    _, err = c.Do("SET", objectPrefix+user.Username, json)
    if err != nil {
        return err
    }
    return nil
}

GET STRUCT

代码语言:javascript
复制
func getStruct(c redis.Conn) error {
    const objectPrefix string = "user:"
    username := "coderminer.com"
    s, err := redis.String(c.Do("GET", objectPrefix+username))
    if err == redis.ErrNil {
        fmt.Println("User does not exist")
    } else if err != nil {
        return err
    }
    user := User{}
    err = json.Unmarshal([]byte(s), &user)
    fmt.Printf("%+v\n", user)
    return nil
}
最终的代码
代码语言:javascript
复制
package main

import (
    "encoding/json"
    "fmt"

    "github.com/garyburd/redigo/redis"
)

type User struct {
    Username  string
    MobileID  string
    Email     string
    FirstName string
    LastName  string
}

func newPool() *redis.Pool {
    return &redis.Pool{
        MaxIdle:   10,
        MaxActive: 12000,
        Dial: func() (redis.Conn, error) {
            c, err := redis.Dial("tcp", ":6379")
            if err != nil {
                panic(err)
            }
            return c, err
        },
    }
}

func ping(c redis.Conn) error {
    pong, err := c.Do("PING")
    if err != nil {
        return err
    }

    s, err := redis.String(pong, err)
    if err != nil {
        return err
    }
    fmt.Printf("PING Response = %s\n", s)
    return nil
}

func set(c redis.Conn) error {
    _, err := c.Do("SET", "Favorite Movie", "Repo Man")
    if err != nil {
        return err
    }
    _, err = c.Do("SET", "Release Year", 1984)
    if err != nil {
        return err
    }
    return nil
}

func get(c redis.Conn) error {
    key := "Favorite Movie"
    s, err := redis.String(c.Do("GET", key))
    if err != nil {
        return err
    }
    fmt.Printf("%s = %s\n", key, s)

    key = "Release Year"
    i, err := redis.Int(c.Do("GET", key))
    if err != nil {
        return err
    }
    fmt.Printf("%s = %d\n", key, i)

    key = "Nonexistent Key"
    s, err = redis.String(c.Do("GET", key))
    if err == redis.ErrNil {
        fmt.Printf("%s does not exist\n", key)
    } else if err != nil {
        return err
    } else {
        fmt.Printf("%s = %s\n", key, s)
    }
    return nil
}

func setStruct(c redis.Conn) error {
    const objectPrefix string = "user:"
    user := User{
        Username:  "coderminer.com",
        MobileID:  "12345678941",
        Email:     "kevin@163.com",
        FirstName: "coderminer.com",
        LastName:  "coderminer.com",
    }

    json, err := json.Marshal(user)
    if err != nil {
        return err
    }

    _, err = c.Do("SET", objectPrefix+user.Username, json)
    if err != nil {
        return err
    }
    return nil
}

func getStruct(c redis.Conn) error {
    const objectPrefix string = "user:"
    username := "coderminer.com"
    s, err := redis.String(c.Do("GET", objectPrefix+username))
    if err == redis.ErrNil {
        fmt.Println("User does not exist")
    } else if err != nil {
        return err
    }
    user := User{}
    err = json.Unmarshal([]byte(s), &user)
    fmt.Printf("%+v\n", user)
    return nil
}

func main() {
    pool := newPool()
    conn := pool.Get()
    defer conn.Close()

    err := ping(conn)
    if err != nil {
        fmt.Println(err)
    }

    err = set(conn)
    if err != nil {
        fmt.Println(err)
    }

    err = get(conn)
    if err != nil {
        fmt.Println(err)
    }

    err = setStruct(conn)
    if err != nil{
        fmt.Println(err)
    }

    err = getStruct(conn)
    if err != nil{
        fmt.Println(err)
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-01-16 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 在Go语言中基础的Redis操作
  • 连接池 POOL
  • 测试连接 PING
  • 最终的代码
相关产品与服务
云数据库 Redis
腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档