當前位置: 首頁>>代碼示例>>Golang>>正文


Golang TProtocol.Flush方法代碼示例

本文整理匯總了Golang中github.com/upfluence/goutils/Godeps/_workspace/src/github.com/upfluence/thrift/lib/go/thrift.TProtocol.Flush方法的典型用法代碼示例。如果您正苦於以下問題:Golang TProtocol.Flush方法的具體用法?Golang TProtocol.Flush怎麽用?Golang TProtocol.Flush使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在github.com/upfluence/goutils/Godeps/_workspace/src/github.com/upfluence/thrift/lib/go/thrift.TProtocol的用法示例。


在下文中一共展示了TProtocol.Flush方法的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

}
開發者ID:upfluence,項目名稱:goutils,代碼行數:18,代碼來源:baseservice.go

示例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
}
開發者ID:upfluence,項目名稱:goutils,代碼行數:60,代碼來源:monitoring.go


注:本文中的github.com/upfluence/goutils/Godeps/_workspace/src/github.com/upfluence/thrift/lib/go/thrift.TProtocol.Flush方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。