亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《连接关闭时 aws lambda 崩溃》很感兴趣。本篇文章就来给大家详细解析一下,主要介绍一下,希望所有认真读完的童鞋们,都有实质性的提高。
问题内容我在 lambda 函数中使用 golang 来连接到 redis。当我第一次调用 lambda 时,会创建一个新的连接池,并进一步调用 lambda 似乎使用该池来获取连接。但是,当我添加 con.close() 行时,对 lambda 的第二次调用会崩溃,而第三次调用将重新创建池。如果不关闭连接会有风险吗?或者我可以通过其他方式关闭连接吗?
我在云监视日志上收到的错误是 pool.get() 行上的“运行时错误、无效内存地址或 nil 指针”,看起来池变量为零?
func newPool(addr string) *redis.Pool {
return &redis.Pool{
MaxIdle: 3,
IdleTimeout: 240 * time.Second,
// Dial or DialContext must be set. When both are set, DialContext takes precedence over Dial.
Dial: func () (redis.Conn, error) { return redis.Dial("tcp", addr) },
}
}
var pool *redis.Pool
func init(){
pool = newPool()
}
func Handle(ctx context.context, req events.APIGatewayWebsocketProxyRequest)(interface{},error){
//make new redis connection
con:= pool.get()
con.close()
}
解决方案
在Handle函数中添加defer con.close()
怎么样?因为在调用 Handle 函数后,它将关闭 con。
到这里,我们也就讲完了《连接关闭时 aws lambda 崩溃》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注编程网公众号,带你了解更多关于的知识点!