首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Lambda超时:将Cloudfront日志从S3导出到ElasticSearch

Lambda超时:将Cloudfront日志从S3导出到ElasticSearch
EN

Stack Overflow用户
提问于 2018-06-11 14:26:39
回答 1查看 486关注 0票数 0

我编写了一个Lambda函数,将Cloudfront日志发送到Elasticsearch中。

工作如下:

  1. Cloudfront将日志(压缩为.gz格式)发送到S3
  2. 桶发送一个由Lambda函数捕获的通知。
  3. 兰博达被触发了。解压缩日志并将它们发送到Elasticsearch中。

我使用这个S3到登录商店温斯顿解析器相结合。

Lambda确实被触发,但是只有一个部分的日志被发送到Elasticsearch,因为Lambda函数超时(我将超时设置为最大值:5分钟)。

我怀疑对.gz日志进行解压缩需要一些时间,但它最多只能是30 KB,这并不多,也不需要很长时间。

我受到这个示例的启发,下面是我的功能:

代码语言:javascript
复制
var s3ToLogstore = require('s3-to-logstore');
var winston = require('winston');
require('winston-elasticsearch');

var elasticsearch = require('elasticsearch');

var client = new elasticsearch.Client({
  host: process.env.ES_HOST,
  log: 'trace'
});

var transport = new winston.transports.Elasticsearch({
  indexPrefix: process.env.ES_INDEXPREFIX,
  client: client
});

var options = {
  format: process.env.FORMAT,
  transport: transport,
  reformatter: function(data){
    data.environment = process.env.STAGE;
    data.origin = process.env.FORMAT;
    return data;
  }
};

exports.handler = s3ToLogstore(options);

云监视日志完全没有问题,而且没有错误。兰博达只是超时了,我不知道为什么。

任何帮助都将不胜感激。

EN

回答 1

Stack Overflow用户

发布于 2018-06-12 09:13:47

很可能elasticsearch客户端保持连接处于打开状态,因此lambda永远不会停止。尝试将keepAlive属性设置为false。

代码语言:javascript
复制
var client = new elasticsearch.Client({
  host: process.env.ES_HOST,
  log: 'trace',
  keepAlive: false
});

请参阅keepAlive和相关属性。https://www.elastic.co/guide/en/elasticsearch/client/javascript-api/current/configuration.html

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50800062

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档