如何解决错误:ConfigurationError:Winston-Elasticsearch的缺少节点选项?

时间:2019-10-14 06:37:34

标签: elasticsearch cucumber winston

  

我想在黄瓜中将日志与ElectricSearch一起使用   我创建了一个Logger类

var winston = require('winston');
var Elasticsearch = require('winston-elasticsearch');
  var instance
  var logger
  var esTransportOpts = {
  level: 'info' 
   }

class Logger { 

    constructor() {
        logger = winston.createLogger({
           transports: [
               new Elasticsearch(esTransportOpts)
          ]
       })
    }

     static getLogger() { 
     if (!instance)  { 
        instance = new Logger()
      }
     return logger
   }


   createLogger () { 
        let logger = winston.createLogger({
           level: 'info',
           format: winston.format.json(),
            defaultMeta: { service: 'user-service' },
            transports: [

                   new winston.transports.File({ filename: 'combined.log' })
            ]
        });

         //
         // If we're not in production then log to the `console` with the format:
         // `${info.level}: ${info.message} JSON.stringify({ ...rest }) `
         // 
         if (process.env.NODE_ENV !== 'production') {
           logger.add(new winston.transports.Console({
            format: winston.format.simple()
        }));
    }

   }


    static addLogging () { 
        winston.add(winston.transports.Logstash, {
          port: 28777,
          node_name: 'my node name',
          host: '127.0.0.1'
        });

    }
}
module.exports = Logger
  

在黄瓜之前声明中,我创建了一个记录器

const { Before, Given, When, Then } = require('cucumber')
const Logger = require('../../src/Logger')

        let a,b, r , logger


         Before(function() {
             logger = Logger.getLogger()
          })

         Given('I have first variable {int}', function (int) {
           logger.info("Multipler")
           a = int

         });



         Given('I have second variable {int}', function (int) {
           b = int

         });

         When('Multiplication a and b', function() {
           r = a*b
         })



         Then('I display the Result  {int}', function (int) {
             int = r
             logger.info(a, "multiplyes with", b, "is", r )
             return int
         });
  

当我执行此黄瓜测试时,我收到错误消息:

     

cucumber2@0.1.0黄瓜   /用户/ steinkorsveien /开发/黄瓜/ cucumber2cucumber-js   “ systemtest / Multiplier.feature” F ----

     

失败:

     

1)方案:将a和b相乘#systemtest / Multiplier.feature:24
  #在#systemtest / step-definition / multiplier.js:7之前         ConfigurationError:缺少节点选项             在新客户端(/Users/steinkorsveien/Development/Cucumber/cucumber2/node_modules/@elastic>/elasticsearch/index.js:52:13)             在新的Elasticsearch(/Users/steinkorsveien/Development/Cucumber/cucumber2/node_modules/winston->elasticsearch/index.js:57:21)            在新的Logger中>(/ Users / steinkorsveien / Development / Cucumber / cucumber2 / src / Logger.js:13:16)             在Function.getLogger>(/ Users / steinkorsveien / Development / Cucumber / cucumber2 / src / Logger.js:20:20)             在世界上。 >(/ Users / steinkorsveien / Development / Cucumber / cucumber2 / systemtest / step-> definition / multiplier.js:8:30)

1 个答案:

答案 0 :(得分:2)

如前所述here

您缺少 elasticsearch 客户端配置。

var esTransportOpts = {
   level: 'info',
   clientOpts: { node: 'http://localhost:9200' }
}

这样你就可以告诉温斯顿将日志转储到哪里。