本文整理汇总了Golang中github.com/upfluence/goutils/Godeps/_workspace/src/github.com/upfluence/thrift/lib/go/thrift.TProtocol.WriteMessageBegin方法的典型用法代码示例。如果您正苦于以下问题:Golang TProtocol.WriteMessageBegin方法的具体用法?Golang TProtocol.WriteMessageBegin怎么用?Golang TProtocol.WriteMessageBegin使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/upfluence/goutils/Godeps/_workspace/src/github.com/upfluence/thrift/lib/go/thrift.TProtocol
的用法示例。
在下文中一共展示了TProtocol.WriteMessageBegin方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: Process
func (p *BaseServiceProcessor) Process(iprot, oprot thrift.TProtocol) (success bool, err thrift.TException) {
name, _, seqId, err := iprot.ReadMessageBegin()
if err != nil {
return false, err
}
if processor, ok := p.GetProcessorFunction(name); ok {
return processor.Process(seqId, iprot, oprot)
}
iprot.Skip(thrift.STRUCT)
iprot.ReadMessageEnd()
x11 := thrift.NewTApplicationException(thrift.UNKNOWN_METHOD, "Unknown function "+name)
oprot.WriteMessageBegin(name, thrift.EXCEPTION, seqId)
x11.Write(oprot)
oprot.WriteMessageEnd()
oprot.Flush()
return false, x11
}
示例2: Process
func (p *monitoringProcessorCollect) Process(seqId int32, iprot, oprot thrift.TProtocol) (success bool, err thrift.TException) {
args := MonitoringCollectArgs{}
if err = args.Read(iprot); err != nil {
iprot.ReadMessageEnd()
x := thrift.NewTApplicationException(thrift.PROTOCOL_ERROR, err.Error())
oprot.WriteMessageBegin("collect", thrift.EXCEPTION, seqId)
x.Write(oprot)
oprot.WriteMessageEnd()
oprot.Flush()
return false, err
}
iprot.ReadMessageEnd()
result := MonitoringCollectResult{}
var retval Metrics
var err2 error
t0 := time.Now().UnixNano()
if retval, err2 = p.handler.Collect(args.Metrics); err2 != nil {
switch v := err2.(type) {
case *ServiceNotAvailable:
thrift.Metrics.Incr("Monitoring.collect.server.exceptions.*ServiceNotAvailable")
result.ServiceUnavailable = v
case *UnknownMetric:
thrift.Metrics.Incr("Monitoring.collect.server.exceptions.*UnknownMetric")
result.UnknownMetric = v
default:
thrift.Metrics.Incr("Monitoring.collect.server.success")
x := thrift.NewTApplicationException(thrift.INTERNAL_ERROR, "Internal error processing collect: "+err2.Error())
oprot.WriteMessageBegin("collect", thrift.EXCEPTION, seqId)
x.Write(oprot)
oprot.WriteMessageEnd()
oprot.Flush()
thrift.Metrics.Incr("Monitoring.collect.server.exceptions.application_error")
return true, err2
}
} else {
thrift.Metrics.Incr("Monitoring.collect.server.success")
result.Success = retval
}
t1 := time.Now().UnixNano()
thrift.Metrics.Timing("Monitoring.collect.server", t1-t0)
if err2 = oprot.WriteMessageBegin("collect", thrift.REPLY, seqId); err2 != nil {
err = err2
}
if err2 = result.Write(oprot); err == nil && err2 != nil {
err = err2
}
if err2 = oprot.WriteMessageEnd(); err == nil && err2 != nil {
err = err2
}
if err2 = oprot.Flush(); err == nil && err2 != nil {
err = err2
}
if err != nil {
return
}
return true, err
}