Source File
trace.go
Belonging Package
google.golang.org/grpc
/*
*
* Copyright 2015 gRPC authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
package grpc
import (
)
// EnableTracing controls whether to trace RPCs using the golang.org/x/net/trace package.
// This should only be set before any RPCs are sent or received by this program.
var EnableTracing bool
// methodFamily returns the trace family for the given method.
// It turns "/pkg.Service/GetFoo" into "pkg.Service".
func ( string) string {
= strings.TrimPrefix(, "/") // remove leading slash
if := strings.Index(, "/"); >= 0 {
= [:] // remove everything from second slash
}
return
}
// traceInfo contains tracing information for an RPC.
type traceInfo struct {
tr trace.Trace
firstLine firstLine
}
// firstLine is the first line of an RPC trace.
// It may be mutated after construction; remoteAddr specifically may change
// during client-side use.
type firstLine struct {
mu sync.Mutex
client bool // whether this is a client (outgoing) RPC
remoteAddr net.Addr
deadline time.Duration // may be zero
}
func ( *firstLine) ( net.Addr) {
.mu.Lock()
.remoteAddr =
.mu.Unlock()
}
func ( *firstLine) () string {
.mu.Lock()
defer .mu.Unlock()
var bytes.Buffer
io.WriteString(&, "RPC: ")
if .client {
io.WriteString(&, "to")
} else {
io.WriteString(&, "from")
}
fmt.Fprintf(&, " %v deadline:", .remoteAddr)
if .deadline != 0 {
fmt.Fprint(&, .deadline)
} else {
io.WriteString(&, "none")
}
return .String()
}
const truncateSize = 100
func ( string, int) string {
if > len() {
return
}
return [:]
}
// payload represents an RPC request or response payload.
type payload struct {
sent bool // whether this is an outgoing payload
msg interface{} // e.g. a proto.Message
// TODO(dsymonds): add stringifying info to codec, and limit how much we hold here?
}
func ( payload) () string {
if .sent {
return truncate(fmt.Sprintf("sent: %v", .msg), truncateSize)
}
return truncate(fmt.Sprintf("recv: %v", .msg), truncateSize)
}
type fmtStringer struct {
format string
a []interface{}
}
func ( *fmtStringer) () string {
return fmt.Sprintf(.format, .a...)
}
type stringer string
func ( stringer) () string { return string() }
The pages are generated with Golds v0.4.9. (GOOS=linux GOARCH=amd64)