0

我一直在玩golang和redis。我只是建立了一个简单的 http 服务器,并想增加 redis 上的请求。我正在炸毁连接(我认为)。我发现使用 redigo 您可以使用连接池,但不确定在我为请求提供服务时如何在 go 中实现它(您从哪里实例化/调用池)。

错误:无法分配请求的地址。

任何建议将不胜感激......我确定我错误地建立了连接,但只是不知道如何改变。

编辑:根据 pauljz 的建议进行了修改——现在效果很好

    var pool redis.Pool

    func qryJson(rw http.ResponseWriter, req *http.Request){

        incrementRedis()
    }

    func incrementRedis () {

    t := time.Now().Format("2006-01-02 15:04:05")
    conn := pool.Get()
    defer conn.Close()
    if _, err := conn.Do("HINCRBY", "messages", t, 1); err != nil {
        log.Fatal(err)

    }


    }

func main() {
    runtime.GOMAXPROCS(runtime.NumCPU())
    pool = redis.Pool{
            MaxIdle: 50,
            MaxActive: 500, // max number of connections
            Dial: func() (redis.Conn, error) {
                    c, err := redis.Dial("tcp", ":6379")
                    if err != nil {
                            panic(err.Error())
                    }
                    return c, err
            },
    } 
    http.HandleFunc("/testqry", qryJson)
    log.Fatal(http.ListenAndServe(":8082", nil))
}
4

2 回答 2

4

redigo 文档有一个很好的连接池入门示例:http: //godoc.org/github.com/garyburd/redigo/redis#Pool

在您的情况下var pool redis.Pool,您的包中有一个(即不在函数内部)。

在调用main()之前,您将从 redigo 示例调用以初始化池。ListenAndServepool = redis.Pool{ ... }

然后incrementRedis()你会做类似的事情:

func incrementRedis () {
    conn := pool.Get()
    defer conn.Close()
    if _, err := conn.Do("HINCRBY", "messages", t, 1); err != nil {
        log.Fatal(err)
    }
}
于 2014-02-25T06:20:29.397 回答
3

在您的代码中,您为每个 http 请求创建一个到 redis 的连接。使用全局变量来存储已连接的 redis 连接并重用它。

于 2014-02-25T05:36:19.003 回答