我在 Google App engine Go Runtime 上使用 Redis Cloud 服务(来自 Redis Labs),当我尝试获取不存在的 key 时出现上述错误。该代码在本地测试服务器上运行良好,但在生产环境中出现故障。
c, err := redis.Dial("tcp", "pub-redis-myredis:<myport>")
_, err = c.Do("AUTH", "password")
value, err := c.Do("GET", "foo4")
if value == nil {
log.Infof(contextOfAppEngineWhereServerIsRunning, "value not found in redislabs")
}
日志显示 panic 发生在行 _, err = c.Do("AUTH", "password")
请您参考如下方法:
在 AppEngine 上,您的应用程序 (webapp) 在沙盒环境中运行,您不能在其中使用标准 net
套接字包(我假设 redislabs 使用)。
您必须使用 appengine/socket
出站网络套接字包。
它很可能在本地有效,因为该限制仅适用于生产环境。
始终检查返回的错误
值。目前在您发布的代码中,您没有检查。如果您检查过它,您会从错误中看到原因。
你得到 invalid memory address or nil pointer dereference
错误,因为你的第一次调用失败了:
c, err := redis.Dial("tcp", "pub-redis-myredis:<myport>")
err
将是一个非 nil
值并且 c
是 nil
这意味着您不能调用它是 Do()
方法。