【发布时间】:2018-12-26 15:47:00
【问题描述】:
我一直在阅读各种文章/文档并观看有关此主题的一些视频。我的问题是它们都以一种或另一种方式发生冲突。
我的目标是使用 winston 将所有 console.logs/error 消息从我的 ec2 服务器发送到 Cloudwatch,这样 ec2 终端本身就不会记录任何日志。
混淆点:
- 如果我使用 winston-aws-cloudwatch 或 winston-cloudwatch,我是否仍需要在 AWS 上设置 IAM 用户,还是这些会在 Cloudwatch 中自动生成日志?
- 如果我按照AWS documentation 设置 Cloudwatch,它会自动将任何控制台日志从 EC2 服务器流式传输到 Cloudwatch,还是两者都做?如果是第一个,那我不需要温斯顿?
- 我是否可以将日志从我的本地开发服务器发送到 Cloudwatch(仅用于测试目的,一旦确定它可以工作,然后我将在暂存中进行测试并最终将其移至生产环境)还是必须来自 EC2 实例?
- 我假设 AWS Cloudwatch 密钥与我用于帐户其余部分的 AWS 密钥相同?
当前代码:
var winston = require('winston'),
CloudWatchTransport = require('winston-aws-cloudwatch');
const logger = new winston.Logger({
transports: [
new (winston.transports.Console)({
timestamp: true,
colorize: true
})
]
});
const cloudwatchConfig = {
logGroupName: 'groupName',
logStreamName: 'streamName',
createLogGroup: false,
createLogStream: true,
awsConfig: {
aws_access_key_id: process.env.AWS_KEY_I_USE_FOR_AWS,
aws_secret_access_key: process.env.AWS_SECRET_KEY_I_USE_FOR_AWS,
region: process.env.REGION_CLOUDWATCH_IS_IN
},
formatLog: function (item) {
return item.level + ': ' + item.message + ' ' + JSON.stringify(item.meta)
}
};
logger.level = 3;
if (process.env.NODE_ENV === 'development') logger.add(CloudWatchTransport, cloudwatchConfig);
logger.stream = {
write: function(message, encoding) {
logger.info(message);
}
};
logger.error('Test log');
【问题讨论】:
标签: amazon-web-services amazon-ec2 amazon-iam amazon-cloudwatch winston