当前位置: 首页>>代码示例>>Golang>>正文


Golang rpc.ServerCodec类代码示例

本文整理汇总了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
}
开发者ID:knorwood,项目名称:cockroach,代码行数:26,代码来源:server.go

示例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)
}
开发者ID:Eric-Gaudiello,项目名称:cockroach,代码行数:26,代码来源:server.go

示例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)
	}
}
开发者ID:alexbrainman,项目名称:delve,代码行数:14,代码来源:server.go

示例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.
		}
	}
}
开发者ID:kaustubhkurve,项目名称:cockroach,代码行数:18,代码来源:server.go


注:本文中的net/rpc.ServerCodec类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。