NodeJSのgoogle-cloud/loggingパッケージを使用してprotopayloadユニオンラベルを渡すにはどうすればよいですか?google-cloud/loggingのprotopayloadを作成するnodejs
これまでのところ、ログにtextPayloadとjsonPayloadを書き込むことができました。
google-protobufとprotobufjsを使用してプロトコルバッファを作成しようとしましたが、プロトコルバッファパッケージを試してみましたが、log.entryとlog.writeを実行するとペイロードはログに表示されません。
これは、書き込みコードはgithubのからnodejs-DOC-サンプルからコピーされる書き込みログ
//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;
}
するためのコードでありますprotopayloadのために私自身の変更はほとんどありません。 サンプルログの書き込みは、jsonPayloadおよびtextPayloadに対してのみ行われました。
[Stackdriver Logs Viewer](https://console.cloud.google.com/logs/viewer)を使用している場合は、ログを書き込んでいる正しい 'logName'と 'resource.type'を表示していることを確認してくださいに。また、「test.proto」が[Google Protocol Buffer言語ガイド](https://developers.google.com/protocol-buffers/docs/proto3#simple)に従っていることを確認してください。ログは表示されますが、ペイロードは表示されない場合は、エンコーダが原因である可能性があります。 'protocol-buffers'の代わりに[google-protobuf](https://www.npmjs.com/package/google-protobuf)を試してみることもできます。 – Jordan
@jordanはい、ログを見ることはできますが、ペイロードは見ることができません。代わりにgoogle-protobufを試してみます。 ありがとう – Root
問題の解決策を見つけられましたか?もしそうならコミュニティへのより良い助けになるように答えとして投稿することをお勧めします。 – Jordan