2

我正在创建一个使用 GRPC 和 protobuf 的 Go 应用程序。我的 RPC 服务将获取包含 type 的消息google.protobuf.Timestamp,对其进行解析并最终将其保存在数据库中或对其执行更多操作。

我对什么被认为是 type 的有效输入感到困惑google.protobuf.Timestamp。我希望对带有时区偏移的日期时间戳使用以下格式。

2019-02-15T13:00:00+01:00

这是我正在使用的原始文件。

syntax = "proto3"
package example;
import "google/protobuf/timestamp.proto"

service Tester {
 rpc ParseDateTimeStamp(TSRequest) returns (TSReply) {}
}

message TSRequest {
  google.protobuf.Timestamp dts = 1;
}

message TSReply {
 string message = 1;
}

问题是当我向 GRPC 服务器发送包含日期时间戳的消息时。我希望给定*tsbp.Timestamp2019-02-15T13:00:00+01:00日期时间戳的类型是有效的,并给我从纪元开始的适当秒数。GetSeconds()(从 timestamp.go调用之后)

为上面的示例输入调用ptypes.TimestampString(ts *tspb.Timestamp)返回1970-01-01T00:00:00Z

是否google.protobuf.Timestamp接受带有 +- 偏移量的日期时间戳?

或者我是否必须将输入输入为 String 类型,然后解析为time.Timewithtime.Format而不是在 protobuf 中使用时间戳变量类型?如果是这样,你能提供一个例子吗?

4

1 回答 1

4

google.protobuf.Timestamp的gRPC消息类型在内部只是两个int64

message Timestamp {
  // Represents seconds of UTC time since Unix epoch
  // 1970-01-01T00:00:00Z. Must be from 0001-01-01T00:00:00Z to
  // 9999-12-31T23:59:59Z inclusive.
  int64 seconds = 1;

  // Non-negative fractions of a second at nanosecond resolution. Negative
  // second values with fractions must still have non-negative nanos values
  // that count forward in time. Must be from 0 to 999,999,999
  // inclusive.
  int32 nanos = 2;
}

所以当在这种格式类型中时,没有什么可以解析的。

通常需要:

  • 像你这样的字符串格式2019-02-15T13:00:00+01:00并转换为time.Time使用time.Parse
  • 然后使用ptypes.TimestampProto()time.Time将其转换为*tspb.Timestamp

仅供参考,在您引用的输出中,您会看到一个zero时间戳(即秒和纳秒都为零) - 因此是"1970-01-01T00:00:00Z"输出。


实现上述流程:

ts, err := time.Parse(time.RFC3339, "2019-02-15T13:00:00+01:00")

pbts, err := ptypes.TimestampProto(ts) // ptypes.Timestamp:"seconds:1550232000 "

fmt.Println(ptypes.TimestampString(pbts)) // "2019-02-15T12:00:00Z"

操场

注意:ptype.Timestamp剥夺了任何时区 -Z所以UTC时间。因此,如果您需要保留 a 的时区,time.Time除了您的消息之外,还需要在您的 gRPC 消息中发送偏移量google.protobuf.Timestamp

于 2019-08-04T02:02:48.017 回答