Подтвердить что ты не робот

Как человек прочитал бы файл журнала json winston?

Кажется приятным для API, скриптов, а что нет. Но чтение трассировки стека winston json очень сложно с помощью текстового редактора. Например.

{"level":"info","message":"starting","timestamp":"2014-05-14T15:45:44.334Z"}
{"date":"Wed May 14 2014 08:45:45 GMT-0700 (Pacific Daylight Time)","process":{"pid":8804,"uid":null,"gid":null,"cwd":"C:\\data\\mytool","execPath":"C:\\Program Files\\nodejs\\node.exe","version":"v0.10.21","argv":["node","C:\\data\\mytool\\server"],"memoryUsage":{"rss":45199360,"heapTotal":32171264,"heapUsed":15158096}},"os":{"loadavg":[0,0,0],"uptime":70496.6138252},"trace":[{"column":null,"file":null,"function":"Object.parse","line":null,"method":"parse","native":true},{"column":32,"file":"C:\\data\\mytool\\src\\status.js","function":"Request._callback","line":166,"method":"_callback","native":false},{"column":22,"file":"C:\\data\\mytool\\node_modules\\request\\request.js","function":"Request.self.callback","line":122,"method":"self.callback","native":false},{"column":17,"file":"events.js","function":"Request.EventEmitter.emit","line":98,"method":"EventEmitter.emit","native":false},{"column":14,"file":"C:\\data\\mytool\\node_modules\\request\\request.js","function":"","line":888,"method":null,"native":false},{"column":20,"file":"events.js","function":"Request.EventEmitter.emit","line":117,"method":"EventEmitter.emit","native":false},{"column":12,"file":"C:\\data\\mytool\\node_modules\\request\\request.js","function":"","line":839,"method":null,"native":false},{"column":20,"file":"events.js","function":"IncomingMessage.EventEmitter.emit","line":117,"method":"EventEmitter.emit","native":false},{"column":16,"file":"_stream_readable.js","function":null,"line":920,"method":null,"native":false},{"column":13,"file":"node.js","function":"process._tickCallback","line":415,"method":"_tickCallback","native":false}],"stack":["SyntaxError: Unexpected end of input","    at Object.parse (native)","    at Request._callback (C:\\data\\mytool\\src\\status.js:166:32)","    at Request.self.callback (C:\\data\\mytool\\node_modules\\request\\request.js:122:22)","    at Request.EventEmitter.emit (events.js:98:17)","    at Request.<anonymous> (C:\\data\\mytool\\node_modules\\request\\request.js:888:14)","    at Request.EventEmitter.emit (events.js:117:20)","    at IncomingMessage.<anonymous> (C:\\data\\mytool\\node_modules\\request\\request.js:839:12)","    at IncomingMessage.EventEmitter.emit (events.js:117:20)","    at _stream_readable.js:920:16","    at process._tickCallback (node.js:415:13)"],"level":"error","message":"uncaughtException: Unexpected end of input","timestamp":"2014-05-14T15:45:45.228Z"}
4b9b3361

Ответ 1

Просто установите для свойства транспорта "json" значение false, и вы получите доступный для пользователя журнал. То же, что вы видите на консоли.

    var winston = require('winston');
    var logger = new winston.Logger({
      transports: [
        new winston.transports.File({
          json: false,
          filename:'log.log'
        }),
        new winston.transports.Console()
      ],
      exitOnError: false
    });
   logger.log('info', 'some msg');

Ответ 2

Пропустите его через jq, что похоже на sed для JSON. Например:.

jq . file.log

Ответ 3

Почему бы просто не запустить его с помощью форматирования JSON в командной строке?

например. (пример из ссылки выше)

echo '{ element0: "lorem", element1: "ipsum" }' | python -mjson.tool

Альтернативой может быть просмотр сборки оболочки script вокруг вышеупомянутого инструмента (или, возможно) jq для выполнения некоторых пользовательский анализ трассировки стека

Ответ 4

Если вы используете Keen.IO, их инструмент CLI может загружать JSON с разделителями строк, тогда вы можете использовать их "Explorer" для фильтрации/просмотр событий журнала.

keen events:add --collection myLogs --file winston-output.json

Ответ 5

Похоже, node bunyan имеет функции, позволяющие фильтровать и просматривать журналы json с помощью человека с помощью CLI.

$ node hi.js | bunyan -l warn
[2013-01-04T19:08:37.182Z]  WARN: myapp/40353 on banana.local: au revoir (lang=fr)

bunyan CLI output

Ответ 6

Вам следует попробовать winston-logs-display.

Демо-выход:

winston-logs-display output

Также Log.io является хорошим вариантом для этого. он поддерживает журнал winston.

Ответ 7

Это медленно, но ваша оболочка может это сделать, получить форматированный, цветной JSON.

./thing | ndjson

asciicast

Как?

В каждой строке используется команда форматирования JSON, синтаксис bash или zsh:

./thing | while read in ; do echo "$in" | python -m json.tool ; done

Для fish синтаксис

./thing | while read in; echo "$in" | python -mjson.tool; end #fish

Чтобы сделать его лишним, просто pip install pygments.

Определите удобный псевдоним pp, поэтому вы запустите cat file.json | pp.

alias pp="python -mjson.tool | pygmentize -l js"

И затем определите ndjson

alias ndjson='while read in; do echo "$in" | pp; done'

Теперь вы можете ввести следующее, чтобы получить форматированный, цветной JSON.

./thing | ndjson

(используйте funced и funcsave для определения псевдонима в fish)