Google App engine-Redislabs Go runtime production error - invalid memory address or nil pointer dereference
Google App engine-Redislabs Go runtime production error - invalid memory address or nil pointer dereference
我在 Google App engine Go Runtime 上使用 Redis 云服务(来自 Redis Labs),当我尝试获取不存在的密钥时出现上述错误。该代码在本地测试服务器上运行良好,但在生产环境中出现故障。
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")
}
日志显示恐慌发生在_, err = c.Do("AUTH", "password")
行
在 AppEngine 上,您的应用程序 (webapp) 在沙盒环境中运行,您不能在其中使用标准 net
套接字包(我假设 redislabs 使用)。
您必须为出站网络套接字使用 appengine/socket
包。
它很可能在本地有效,因为该限制仅适用于生产环境。
始终检查返回的 error
值。当前在您发布的代码中,您检查 none。如果您检查过它,您会从错误中看到原因。
您收到 invalid memory address or nil pointer dereference
错误,因为您的第一次调用失败:
c, err := redis.Dial("tcp", "pub-redis-myredis:<myport>")
err
将是一个非 nil
值,而 c
是 nil
,这意味着您不能调用它的 Do()
方法。
我在 Google App engine Go Runtime 上使用 Redis 云服务(来自 Redis Labs),当我尝试获取不存在的密钥时出现上述错误。该代码在本地测试服务器上运行良好,但在生产环境中出现故障。
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")
}
日志显示恐慌发生在_, err = c.Do("AUTH", "password")
在 AppEngine 上,您的应用程序 (webapp) 在沙盒环境中运行,您不能在其中使用标准 net
套接字包(我假设 redislabs 使用)。
您必须为出站网络套接字使用 appengine/socket
包。
它很可能在本地有效,因为该限制仅适用于生产环境。
始终检查返回的 error
值。当前在您发布的代码中,您检查 none。如果您检查过它,您会从错误中看到原因。
您收到 invalid memory address or nil pointer dereference
错误,因为您的第一次调用失败:
c, err := redis.Dial("tcp", "pub-redis-myredis:<myport>")
err
将是一个非 nil
值,而 c
是 nil
,这意味着您不能调用它的 Do()
方法。