Есть ли способ вывести журналы, используя log4 js в облачных функциях? - PullRequest
1 голос
/ 06 марта 2020

Я использую облачную функцию GCP. Чего я хочу добиться, так это выводить журналы по log4 js.

. Я знаю и пробовал, чтобы использование console.xxx () работало хорошо.

Среда: - Облачные функции Google - Функции -framework - nodejs10 as Runtime

logger. js

const log4js = require('log4js');

const logger = exports = module.exports = {};

log4js.configure({
  appenders: {
    out: { type: 'console' },
    trail: {
      type: 'dateFile',
      filename: './logs/trail',
      pattern: '-yyyy-MMdd-hh.log',
      alwaysIncludePattern: true
    }
  },
  categories: {
    default: { appenders: [ 'out' ], level: 'info' },
    trail: { appenders: [ 'trail' ], level: 'DEBUG' }
  }
})

logger.trail = log4js.getLogger('trail')

index. js

const { logger } = require('./logger');

exports.spTest = (pubSubEvent, context) => {
  console.log('console.log should appear'); // => properly logged
  logger.trail.error('logger should appear'); => doesn't show up
};

Заранее спасибо!

1 Ответ

2 голосов
/ 06 марта 2020

Согласно официальной документации ссылка :

Cloud Logging является частью набора продуктов Google Cloud для операций в Google Cloud. Он включает в себя хранилище для журналов, пользовательский интерфейс, называемый средством просмотра журналов, и API для программного управления журналами.

Также Пользовательские журналы StackDriver

Журналы облачных функций поддерживаются журналом StackDriver. Вы можете использовать библиотеку StackDriver Logging для Node.js для регистрации событий со структурированными данными, что упрощает анализ и мониторинг.


const { Logging } = require('@google-cloud/logging');

// ...

// Instantiate the StackDriver Logging SDK. The project ID will
// be automatically inferred from the Cloud Functions environment.
const logging = new Logging();
const log = logging.log('my-custom-log-name');

// This metadata is attached to each log entry. This specifies a fake
// Cloud Function called 'Custom Metrics' in order to make your custom
// log entries appear in the Cloud Functions logs viewer.
const METADATA = {
  resource: {
    type: 'cloud_function',
    labels: {
      function_name: 'CustomMetrics',
      region: 'us-central1'
    }
  }
};

// ...

// Data to write to the log. This can be a JSON object with any properties
// of the event you want to record.
const data = {
  event: 'my-event',
  value: 'foo-bar-baz',

  // Optional 'message' property will show up in the Firebase
  // console and other human-readable logging surfaces
  message: 'my-event: foo-bar-baz'
};

// Write to the log. The log.write() call returns a Promise if you want to
// make sure that the log was written successfully.
const entry = log.entry(METADATA, data);
log.write(entry);index.js

Поэтому я не думаю, что вы можете использовать log4 js на Облачные функции.

...