本文将探讨Redis作为非关系数据存储的一种形式,并展示Go等语言如何与这些服务进行交互。

由于Redis通过简单的接口支持键值存储,因此它是会话存储或具有持续时间的临时数据的理想选择。为Redis中存储的数据指定超时的能力非常有价值。本节将探讨从配置,查询到使用自定义排序的基本Redis用法。

实践

获取第三方库:

go get gopkg.in/redis.v5

建立 config.go:

package redis

import (
    "os"

    redis "gopkg.in/redis.v5"
)

// Setup 初始化 redis 连接
func Setup() (*redis.Client, error) {
    client := redis.NewClient(&redis.Options{
        Addr:     "localhost:6379",
        Password: os.Getenv("REDISPASSWORD"),
        DB:       0, // 使用默认 DB
    })

    // 命令返回“PONG”,测试连接是否存活
    _, err := client.Ping().Result()
    return client, err
}

建立 exec.go:

package redis

import (
    "fmt"
    "time"

    redis "gopkg.in/redis.v5"
)

// Exec 执行一些redis操作
func Exec() error {
    conn, err := Setup()
    if err != nil {
        return err
    }

    c1 := "value"
    // 我们可以把任何想要的类型存入key所对应的值
    // 当前存入的是key到期的时间
    conn.Set("key", c1, 5*time.Second)

    var result string
    if err := conn.Get("key").Scan(&result); err != nil {
        switch err {
        // 这意味着key找不到对应的值
        case redis.Nil:
            return nil
        default:
            return err
        }
    }

    fmt.Println("result =", result)

    return nil
}

建立 sort.go:

package redis

import (
    "fmt"

    redis "gopkg.in/redis.v5"
)

// Sort 执行排序redis操作
func Sort() error {
    conn, err := Setup()
    if err != nil {
        return err
    }

    if err := conn.LPush("list", 1).Err(); err != nil {
        return err
    }
    if err := conn.LPush("list", 3).Err(); err != nil {
        return err
    }
    if err := conn.LPush("list", 2).Err(); err != nil {
        return err
    }

    res, err := conn.Sort("list", redis.Sort{Order: "ASC"}).Result()
    if err != nil {
        return err
    }
    fmt.Println(res)
    conn.Del("list")
    return nil
}

建立 main.go:

package main

import "github.com/agtorre/go-cookbook/chapter5/redis"

func main() {
    if err := redis.Exec(); err != nil {
        panic(err)
    }

    if err := redis.Sort(); err != nil {
        panic(err)
    }
}

这会输出:

result = value
[1 2 3]

说明

可以看到Redis的操作与MySQL很相似,Scan()等函数都遵循相同的约定从Redis读取数据映射Go类型。选择合适的第三方库可能具有挑战性,我建议定期调查可用的内容。

本节使用redis包进行基本设置和查询,执行更复杂的排序功能。与database/sql一样,你可以通过控制超时,设置连接池大小等形式设置其他配置。Redis本身还提供了许多其他功能,包括Redis群集支持,Zscore和计数器对象,分布式锁定等。

与前面的章节一样,我建议使用配置对象,它存储Redis设置和配置详细信息,以便于设置操作和提高安全性。

最后编辑: kuteng  文档更新时间: 2021-01-03 15:03   作者:kuteng