duangang1991
2018-07-26 06:37
浏览 80
已采纳

来自外部软件包的AWS Lambda golang日志记录

I'm starting to use external packages for my lambda function which is written in Golang.

I use serverless framework if that makes any difference.

I want to centralize the error logging every time there's an error in the DB.

but I notice that the log doesn't show on the cloudwatch. Only the logs in the main package shows.

here's my code

package response
func ServerError(err error) (events.APIGatewayProxyResponse, error) {
    log.Print(fmt.Errorf("ERROR: %v", err))
    return Custom(500, "Internal Server Error", nil)
}

I also tried

package response
func ServerError(err error) (events.APIGatewayProxyResponse, error) {
    fmt.Println(fmt.Errorf("ERROR: %v", err))
    return Custom(500, "Internal Server Error", nil)
}

My question is how can I enable logging in lambda outside of main package?

Thanks!

EDIT

It turns out that log.Print(fmt.Errorf("ERROR: %v", err)) works as well. I must've missed it the last time.

图片转代码服务由CSDN问答提供 功能建议

我开始将外部软件包用于用Golang编写的lambda函数。

如果有什么区别,我会使用无服务器框架。

我希望每次数据库中出现错误时都集中记录错误。

但是我注意到日志没有显示在cloudwatch上。 仅显示 main 包中的日志。

这是我的代码

 包响应
func ServerError( 错误错误)(events.APIGatewayProxyResponse,错误){
 log.Print(fmt.Errorf(“ ERROR:%v”,err))
返回自定义(500,“内部服务器错误”,nil)
} \  n   
 
 

我也尝试了

 包响应
func ServerError(错误错误)(events.APIGatewayProxyResponse,错误){  
 fmt.Println(fmt.Errorf(“ ERROR:%v”,err))
返回自定义(500,“内部服务器错误”,nil)
} 
   
  
 

我的问题是如何在主程序包之外启用lambda登录?

谢谢!

EDIT \ n

事实证明 log.Print(fmt.Errorf(“ ERROR:%v”,err))也可以正常工作。 我上次一定很想念它。

  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • dpgu5074 2018-08-27 17:30
    已采纳

    In the serverless framework anything printed to std.out/std err will be written to the cloudwatch logs. Therefore all you have to do is write your errors to std.err

    fmt.Fprintf(os.Stderr, "log message: %s", str)

    This post touches on writing to std.err https://stackoverflow.com/a/40694000/2840591

    已采纳该答案
    打赏 评论

相关推荐 更多相似问题