AWS EB Node.JS登录CloudWatch

时间:2015-08-28 11:53:14

标签: node.js amazon-web-services elastic-beanstalk amazon-cloudwatch

是否有任何可能的解决方案将在Elastic Beanstalk上运行的应用程序的Node.JS日志流式传输到Amazon CloudWatch?

我确实看到了 cwl-webrequest-metrics.config 文件,但没有关于它格式的信息我无法将其格式化为仅将Node.JS日志(仅)传输到CloudWatch。

提前征求您的意见!

1 个答案:

答案 0 :(得分:4)

问题有点老了,但是对于那些来自Google的人来说,这是一个工作.ebextension配置Node.JS日志流到cloudwatch:

# Store Node.JS Application Logs in Cloudwatch
Mappings:
  CWLogs:
    NodeJSLogGroup:
      LogFile: "/var/log/nodejs/nodejs.log"
      TimestampFormat: "%d/%b/%Y:%H:%M:%S %z"

Outputs:
  NodeJSCWLogGroup:
    Description: "Node.JS Application Logs"
    Value: { "Ref" : "AWSEBCloudWatchLogs8832c8d3f1a54c238a40e36f31ef55a0NodeJSLogGroup"}


Resources :
  AWSEBCloudWatchLogs8832c8d3f1a54c238a40e36f31ef55a0NodeJSLogGroup:    ## Must have prefix:  AWSEBCloudWatchLogs8832c8d3f1a54c238a40e36f31ef55a0
    Type: "AWS::Logs::LogGroup"
    DependsOn: AWSEBBeanstalkMetadata
    DeletionPolicy: Retain     ## this is required
    Properties:
      LogGroupName:
        "Fn::GetOptionSetting":
          Namespace: "aws:elasticbeanstalk:application:environment"
          OptionName: NodeJSCWLogGroup
          DefaultValue: {"Fn::Join":["-", [{ "Ref":"AWSEBEnvironmentName" }, "nodejs"]]}
      RetentionInDays: 14


  ## Register the files/log groups for monitoring
  AWSEBAutoScalingGroup:
    Metadata:
      "AWS::CloudFormation::Init":
        CWLogsAgentConfigSetup:
          files:
            ## any .conf file put into /tmp/cwlogs/conf.d will be added to the cwlogs config (see cwl-agent.config)
            "/tmp/cwlogs/conf.d/nodejs.conf":
              content : |
                [nodjs-log]
                file = `{"Fn::FindInMap":["CWLogs", "NodeJSLogGroup", "LogFile"]}`
                log_group_name = `{ "Ref" : "AWSEBCloudWatchLogs8832c8d3f1a54c238a40e36f31ef55a0NodeJSLogGroup" }`
                log_stream_name = {instance_id}
                datetime_format = `{"Fn::FindInMap":["CWLogs", "NodeJSLogGroup", "TimestampFormat"]}`
              mode  : "000400"
              owner : root
              group : root

看起来http://serebrov.github.io/html/2015-05-20-cloudwatch-setup.html也可能是一个很好的参考。

相关问题