我在 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 值并且 cnil 这意味着您不能调用它是 Do() 方法。


评论关闭
IT虾米网

微信公众号号:IT虾米 (左侧二维码扫一扫)欢迎添加!