我们如何在 NodeJS 中使用 google-cloud/logging 包传递 protopayload 联合标签?
到目前为止,我能够在日志中写入 textPayload 和 jsonPayload。
尝试使用 google-protobuf 和 protobufjs 创建协议缓冲区,甚至尝试了协议缓冲区包,但是当我执行 log.entry 和 log.write 时,在日志中看不到有效负载。
这是写日志的代码
//writelogs.js
function writeLogEntryAdvanced (logName, options, callback) {
var logging = Logging();
var log = logging.log(logName);
var protobuf = require('protocol-buffers');
var fs = require('file-system');
// pass a proto file as a buffer/string or pass a parsed protobuf-schema object
var messages = protobuf(fs.readFileSync('test.proto'));
var buf = messages.Test.encode({
num: 42,
payload: 'hello world'
});
console.log(buf);
var entry = log.entry({ resource: options.resource }, buf);
// See https://googlecloudplatform.github.io/google-cloud-node/#/docs/logging/latest/logging/log?method=write
log.write(entry, function (err, apiResponse) {
if (err) {
return callback(err);
}
console.log('Wrote entry to log: %s', logName);
return callback(null, apiResponse);
});
}
//test.proto
message Test {
required float num = 1;
required string payload = 2;
}
编写代码是从 github 的 nodejs-doc-samples 复制的,我自己对 protopayload 的更改很少。示例日志写入仅适用于 jsonPayload 和 textPayload。