
Adds a new field to the `Request` type which specifies a timeout (in nanoseconds) for the request. This is propagated on method dispatch as a context timeout. There was some discussion here on supporting a broader "metadata" field (similar to grpc) that can be used for other things, but we ended up with a dedicated field because it is lighter weight and expect it to be used pretty heavily as is.... metadata may be added in the future, but is not necessary for timeouts. Also discussed using a deadline vs a timeout in the request and decided to go with a timeout in order to deal with potential clock skew between the client and server. This also has the side-effect of eliminating the protocol/wire overhead from the request timeout. Signed-off-by: Brian Goff <cpuguy83@gmail.com>
44 lines
1.4 KiB
Go
44 lines
1.4 KiB
Go
/*
|
|
Copyright The containerd Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package ttrpc
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
spb "google.golang.org/genproto/googleapis/rpc/status"
|
|
)
|
|
|
|
type Request struct {
|
|
Service string `protobuf:"bytes,1,opt,name=service,proto3"`
|
|
Method string `protobuf:"bytes,2,opt,name=method,proto3"`
|
|
Payload []byte `protobuf:"bytes,3,opt,name=payload,proto3"`
|
|
TimeoutNano int64 `protobuf:"varint,4,opt,name=timeout_nano,proto3"`
|
|
}
|
|
|
|
func (r *Request) Reset() { *r = Request{} }
|
|
func (r *Request) String() string { return fmt.Sprintf("%+#v", r) }
|
|
func (r *Request) ProtoMessage() {}
|
|
|
|
type Response struct {
|
|
Status *spb.Status `protobuf:"bytes,1,opt,name=status,proto3"`
|
|
Payload []byte `protobuf:"bytes,2,opt,name=payload,proto3"`
|
|
}
|
|
|
|
func (r *Response) Reset() { *r = Response{} }
|
|
func (r *Response) String() string { return fmt.Sprintf("%+#v", r) }
|
|
func (r *Response) ProtoMessage() {}
|