4

我想阅读 BigQuery 日志条目以进行一些分析。但我似乎无法protoPayload.value解码。我试过弄乱google-proto-filesandprotocol-buffers包,但我想我在这里遗漏了一些非常明显的东西......

const Logging = require('@google-cloud/logging');
const protobuf = require('protocol-buffers');
const protoFiles = require('google-proto-files');


const protoPath = './node_modules/google-proto-files/google/cloud/audit/audit_log.proto';
const root = protoFiles.loadSync(protoPath)
const AuditLog = root.lookup('google.cloud.audit.AuditLog');

const client = new Logging.v2.LoggingServiceV2Client({ projectId });
client.listLogEntriesStream({resourceNames, filter, pageSize})
    .on('data', entry => {
        console.log(entry); // Entry is of type AuditLog
        console.log(AuditLog.decode(entry.protoPayload.value.buffer));
        process.exit(1)
    })
    .on('error', e => console.error(e))
    .on('end', () => console.info('END RECEIVED', arguments))

我确实收到了带有 protoPayloads 的消息,但是在尝试解码消息时收到的错误是:

Error: no such Type or Enum 'google.rpc.Status' in Type .google.cloud.audit.AuditLog

protoPayload实际问题:解码 a 中的字段的正确方法是LogEntry什么?

谢谢!

4

1 回答 1

1

由于这entry.protoPayload.value是一个序列化的原型(一个 AuditLog 消息),您应该能够使用https://developers.google.com/protocol-buffers/docs/reference/javascript-generated#message中记录的 deserializeBinary() 方法来处理 它'protocol-buffers' npm 似乎不是来自 Google,并且 proto 编译器将生成用于反序列化的代码。

我不希望您需要,但您也可以尝试显式加载“google/rpc/status.proto”定义。

于 2018-06-22T15:58:00.123 回答