本文整理汇总了Golang中net/rpc.ServerCodec类的典型用法代码示例。如果您正苦于以下问题:Golang ServerCodec类的具体用法?Golang ServerCodec怎么用?Golang ServerCodec使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了ServerCodec类的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: readRequest
// readRequest reads a single request from a connection.
func (s *Server) readRequest(codec rpc.ServerCodec, authHook func(proto.Message, bool) error) (
req rpc.Request, m method, args proto.Message, err error) {
if err = codec.ReadRequestHeader(&req); err != nil {
return
}
s.mu.RLock()
var ok bool
m, ok = s.methods[req.ServiceMethod]
s.mu.RUnlock()
// If we found the method, construct a request protobuf and parse into it.
// If not, consume and discard the input by passing nil to ReadRequestBody.
if ok {
args = reflect.New(m.reqType.Elem()).Interface().(proto.Message)
}
if err = codec.ReadRequestBody(args); err != nil {
return
}
if args == nil {
return
}
err = authHook(args, m.public)
return
}
示例2: readRequest
// readRequest reads a single request from a connection.
func (s *Server) readRequest(codec rpc.ServerCodec, authHook func(proto.Message, bool) error) (rpc.Request, method, proto.Message, error) {
var req rpc.Request
if err := codec.ReadRequestHeader(&req); err != nil {
return req, method{}, nil, err
}
s.mu.RLock()
m, ok := s.methods[req.ServiceMethod]
s.mu.RUnlock()
// If we found the method, construct a request protobuf, parse into
// it, and authenticate it.
if ok {
args := reflect.New(m.reqType.Elem()).Interface().(proto.Message)
if err := codec.ReadRequestBody(args); err != nil {
return req, m, args, err
}
return req, m, args, authHook(args, m.public)
}
// If not, consume and discard the input by passing nil to ReadRequestBody.
return req, m, nil, codec.ReadRequestBody(nil)
}
示例3: sendResponse
func (s *ServerImpl) sendResponse(sending *sync.Mutex, req *rpc.Request, resp *rpc.Response, reply interface{}, codec rpc.ServerCodec, errmsg string) {
resp.ServiceMethod = req.ServiceMethod
if errmsg != "" {
resp.Error = errmsg
reply = invalidRequest
}
resp.Seq = req.Seq
sending.Lock()
defer sending.Unlock()
err := codec.WriteResponse(resp, reply)
if err != nil {
log.Println("rpc: writing response:", err)
}
}
示例4: sendResponses
// sendResponses sends a stream of responses on a connection, and
// exits when the channel is closed.
func (s *Server) sendResponses(codec rpc.ServerCodec, responses <-chan serverResponse) {
for resp := range responses {
rpcResp := rpc.Response{
ServiceMethod: resp.req.ServiceMethod,
Seq: resp.req.Seq,
}
if resp.err != nil {
rpcResp.Error = resp.err.Error()
}
if err := codec.WriteResponse(&rpcResp, resp.reply); err != nil {
log.Warningf("rpc: write response failed: %s", err)
// TODO(bdarnell): what to do at this point? close the connection?
// net/rpc just swallows the error.
}
}
}