本文整理匯總了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.
}
}
}