Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
N
neoppod
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Levin Zimmermann
neoppod
Commits
137a5964
Commit
137a5964
authored
Jul 05, 2017
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
3ea91beb
Changes
13
Hide whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
130 additions
and
23 deletions
+130
-23
go/neo/client/client.go
go/neo/client/client.go
+1
-1
go/neo/cmd/neo/neo.go
go/neo/cmd/neo/neo.go
+1
-1
go/neo/neo.go
go/neo/neo.go
+1
-1
go/neo/neotools/doc.go
go/neo/neotools/doc.go
+1
-1
go/neo/server/doc.go
go/neo/server/doc.go
+1
-1
go/xcommon/tracing/cmd/gotrace/gotrace.go
go/xcommon/tracing/cmd/gotrace/gotrace.go
+12
-5
go/xcommon/tracing/tracing.go
go/xcommon/tracing/tracing.go
+106
-7
go/xcommon/xio/xio.go
go/xcommon/xio/xio.go
+1
-1
go/xcommon/xnet/net.go
go/xcommon/xnet/net.go
+1
-1
go/xcommon/xnet/pipenet/pipenet.go
go/xcommon/xnet/pipenet/pipenet.go
+1
-1
go/xcommon/xsync/xsync.go
go/xcommon/xsync/xsync.go
+1
-1
go/xcommon/xtesting/xtesting.go
go/xcommon/xtesting/xtesting.go
+1
-1
go/zodb/wks/wks.go
go/zodb/wks/wks.go
+2
-1
No files found.
go/neo/client/client.go
View file @
137a5964
...
@@ -17,7 +17,7 @@
...
@@ -17,7 +17,7 @@
// See COPYING file for full licensing terms.
// See COPYING file for full licensing terms.
// See https://www.nexedi.com/licensing for rationale and options.
// See https://www.nexedi.com/licensing for rationale and options.
// Package client provides ZODB interface for accessing NEO cluster
// Package client provides ZODB interface for accessing NEO cluster
.
package
client
package
client
import
(
import
(
...
...
go/neo/cmd/neo/neo.go
View file @
137a5964
...
@@ -17,7 +17,7 @@
...
@@ -17,7 +17,7 @@
// See COPYING file for full licensing terms.
// See COPYING file for full licensing terms.
// See https://www.nexedi.com/licensing for rationale and options.
// See https://www.nexedi.com/licensing for rationale and options.
// Neo is a driver program for running & invoking NEO commands and services
// Neo is a driver program for running & invoking NEO commands and services
.
package
main
package
main
import
(
import
(
...
...
go/neo/neo.go
View file @
137a5964
...
@@ -17,7 +17,7 @@
...
@@ -17,7 +17,7 @@
// See COPYING file for full licensing terms.
// See COPYING file for full licensing terms.
// See https://www.nexedi.com/licensing for rationale and options.
// See https://www.nexedi.com/licensing for rationale and options.
// Package neo and its children provide distributed object storage for ZODB
// Package neo and its children provide distributed object storage for ZODB
.
//
//
// Package neo itself provides protocol definition and common infrastructure.
// Package neo itself provides protocol definition and common infrastructure.
// See packages neo.client and neo.server for client and server sides respectively.
// See packages neo.client and neo.server for client and server sides respectively.
...
...
go/neo/neotools/doc.go
View file @
137a5964
...
@@ -17,5 +17,5 @@
...
@@ -17,5 +17,5 @@
// See COPYING file for full licensing terms.
// See COPYING file for full licensing terms.
// See https://www.nexedi.com/licensing for rationale and options.
// See https://www.nexedi.com/licensing for rationale and options.
// Package neotools provides tools for running and managing NEO databases
// Package neotools provides tools for running and managing NEO databases
.
package
neotools
package
neotools
go/neo/server/doc.go
View file @
137a5964
...
@@ -17,5 +17,5 @@
...
@@ -17,5 +17,5 @@
// See COPYING file for full licensing terms.
// See COPYING file for full licensing terms.
// See https://www.nexedi.com/licensing for rationale and options.
// See https://www.nexedi.com/licensing for rationale and options.
// Package server provides servers side of NEO
// Package server provides servers side of NEO
.
package
server
package
server
go/xcommon/tracing/cmd/gotrace/gotrace.go
View file @
137a5964
...
@@ -18,17 +18,19 @@
...
@@ -18,17 +18,19 @@
// See https://www.nexedi.com/licensing for rationale and options.
// See https://www.nexedi.com/licensing for rationale and options.
/*
/*
gotrace TODO
Gotrace is a program to support and interact with go tracing subsystem.
gen generates code according to tracing annotations and imports
Gotrace is a common entry to tracing and provides several subcommands:
list lists tracepoints defined in a package
gotrace gen package
gen generate code according to tracing annotations and imports
gotrace list package TODO
list lists tracepoints defined in a package
XXX tracepoints this package defines
XXX tracepoints this package defines
XXX tracepoints this package imports
XXX tracepoints this package imports
See package lab.nexedi.com/kirr/go123/tracing documentation on how to define
and use trace events in programs. XXX
FIXME build tags not taken into account
FIXME build tags not taken into account
*/
*/
package
main
package
main
...
@@ -514,6 +516,7 @@ func {{.ImportSpec.PkgName}}_{{.Name}}_Attach(*tracing.ProbeGroup, func({{.ArgvT
...
@@ -514,6 +516,7 @@ func {{.ImportSpec.PkgName}}_{{.Name}}_Attach(*tracing.ProbeGroup, func({{.ArgvT
// traceEventImportCheckTmpl is code template generated to check consistency with one imported package
// traceEventImportCheckTmpl is code template generated to check consistency with one imported package
var
traceEventImportCheckTmpl
=
template
.
Must
(
template
.
New
(
"traceimportcheck"
)
.
Parse
(
`
var
traceEventImportCheckTmpl
=
template
.
Must
(
template
.
New
(
"traceimportcheck"
)
.
Parse
(
`
{{/* linking will fail if trace import code becomes out of sync wrt imported package */ -}}
// rerun "gotrace gen" if you see link failure ↓↓↓
// rerun "gotrace gen" if you see link failure ↓↓↓
//go:linkname {{.ImportSpec.PkgName}}_trace_exporthash {{.ImportSpec.PkgPath}}._trace_exporthash_{{.ExportHash}}
//go:linkname {{.ImportSpec.PkgName}}_trace_exporthash {{.ImportSpec.PkgPath}}._trace_exporthash_{{.ExportHash}}
func {{.ImportSpec.PkgName}}_trace_exporthash()
func {{.ImportSpec.PkgName}}_trace_exporthash()
...
@@ -897,6 +900,10 @@ func traceExportHash(tpkg *Package, kind string) string {
...
@@ -897,6 +900,10 @@ func traceExportHash(tpkg *Package, kind string) string {
return
fmt
.
Sprintf
(
"%x"
,
sha1
.
Sum
(
traceExport
(
tpkg
,
kind
)))
return
fmt
.
Sprintf
(
"%x"
,
sha1
.
Sum
(
traceExport
(
tpkg
,
kind
)))
}
}
// TODO
// func tracelist(...)
func
main
()
{
func
main
()
{
log
.
SetFlags
(
0
)
log
.
SetFlags
(
0
)
log
.
SetPrefix
(
"gotrace: "
)
log
.
SetPrefix
(
"gotrace: "
)
...
...
go/xcommon/tracing/tracing.go
View file @
137a5964
...
@@ -18,16 +18,115 @@
...
@@ -18,16 +18,115 @@
// See https://www.nexedi.com/licensing for rationale and options.
// See https://www.nexedi.com/licensing for rationale and options.
/*
/*
Package tracing provides runtime and usage support for Go tracing facilities
Package tracing provides runtime and usage support for Go tracing facilities
.
TODO describe how to define tracepoints
TODO doc:
- tracepoints
- probes
- probes can be attached/detached to/from tracepoints
TODO document //trace:event & //trace:import
Trace events
A Go package can define several events of interest to trace via special
comments. With such definition a tracing event becomes associated with trace
function that is used to signal when the event happens. For example:
package hello
//trace:event traceHelloPre(who string)
//trace:event traceHello(who string)
func SayHello(who string) {
traceHelloPre(who)
fmt.Println("Hello, %s", who)
traceHello(who)
}
By default trace function does nothing and has very small overhead(*).
Probes
However it is possible to attach probing functions to events. A probe, once
attached, is called whenever event is signalled in the context which triggered
the event and pauses original code execution until the probe is finished. It is
possible to attach several probing functions to the same event and dynamically
detach/(re-)attach them. Attaching/detaching probes must be done under
tracing.Lock. For example:
type saidHelloT struct {
who string
when time.Time
}
saidHello := make(chan saidHelloT)
tracing.Lock()
p := traceHello_Attach(nil, func(who string) {
saidHello <- saidHelloT{who, time.Now()}
})
tracing.Unlock()
go func() {
for hello := range saidHello {
fmt.Printf("Said hello to %v @ %v\n", hello.who, hello.when)
}
}()
SayHello("JP")
SayHello("Kirr")
SayHello("Varya")
tracing.Lock()
p.Detach()
tracing.Unlock()
close(saidHello)
For convenience it is possible to keep group of attached probes and detach them
all at once using ProbeGroup:
pg := &tracing.ProbeGroup{}
tracing.Lock()
traceHelloPre_Attach(pg, func(who string) { ... })
traceHello_Attach(pg, func(who string) { ... })
tracing.Unlock()
// some activity
// when probes needs to be detached (no explicit tracing.Lock needed):
pg.Done()
Probes is general mechanism which allows various kind of usage of trace events.
Cross package tracing
Trace events are not part of exported package API with rationale that package's
regular API and internal trace events usually have different stability
commitments. However with tracing-specific importing mechanism it is possible
to get access to trace events another package provides:
package another
//trace:import "hello"
This will make _Attach functions for all tracing events from package hello be
available as regular functions prefixed with imported package name:
tracing.Lock()
hello_traceHello_Attach(nil, func(who string) {
fmt.Printf("SayHello in package hello: %s", who)
tracing.Unlock()
...
Gotrace
TODO document `gotrace gen` + `gotrace list`
TODO document `gotrace gen` + `gotrace list`
--------
(*) conditionally checking whether a pointer != nil. After
https://golang.org/issues/19348 is implemented the call/return overhead will be
also gone.
*/
*/
package
tracing
package
tracing
...
...
go/xcommon/xio/xio.go
View file @
137a5964
// TODO copyright / license
// TODO copyright / license
// Package xio provides addons to standard package io
// Package xio provides addons to standard package io
.
package
xio
package
xio
import
(
import
(
...
...
go/xcommon/xnet/net.go
View file @
137a5964
...
@@ -17,7 +17,7 @@
...
@@ -17,7 +17,7 @@
// See COPYING file for full licensing terms.
// See COPYING file for full licensing terms.
// See https://www.nexedi.com/licensing for rationale and options.
// See https://www.nexedi.com/licensing for rationale and options.
// Package xnet provides addons to std package net
// Package xnet provides addons to std package net
.
package
xnet
package
xnet
import
(
import
(
...
...
go/xcommon/xnet/pipenet/pipenet.go
View file @
137a5964
...
@@ -17,7 +17,7 @@
...
@@ -17,7 +17,7 @@
// See COPYING file for full licensing terms.
// See COPYING file for full licensing terms.
// See https://www.nexedi.com/licensing for rationale and options.
// See https://www.nexedi.com/licensing for rationale and options.
// Package pipenet provides TCP-like synchronous in-memory network of net.Pipes
// Package pipenet provides TCP-like synchronous in-memory network of net.Pipes
.
//
//
// Addresses on pipenet are host:port pairs. A host is xnet.Networker and so
// Addresses on pipenet are host:port pairs. A host is xnet.Networker and so
// can be worked with similarly to regular TCP network with Dial/Listen/Accept/...
// can be worked with similarly to regular TCP network with Dial/Listen/Accept/...
...
...
go/xcommon/xsync/xsync.go
View file @
137a5964
...
@@ -17,7 +17,7 @@
...
@@ -17,7 +17,7 @@
// See COPYING file for full licensing terms.
// See COPYING file for full licensing terms.
// See https://www.nexedi.com/licensing for rationale and options.
// See https://www.nexedi.com/licensing for rationale and options.
// Package xsync provides addons to packages "sync" and "golang.org/x/sync"
// Package xsync provides addons to packages "sync" and "golang.org/x/sync"
.
package
xsync
package
xsync
import
(
import
(
...
...
go/xcommon/xtesting/xtesting.go
View file @
137a5964
...
@@ -17,7 +17,7 @@
...
@@ -17,7 +17,7 @@
// See COPYING file for full licensing terms.
// See COPYING file for full licensing terms.
// See https://www.nexedi.com/licensing for rationale and options.
// See https://www.nexedi.com/licensing for rationale and options.
// Package xtesting provides addons to std package testing
// Package xtesting provides addons to std package testing
.
package
xtesting
package
xtesting
import
(
import
(
...
...
go/zodb/wks/wks.go
View file @
137a5964
...
@@ -17,7 +17,8 @@
...
@@ -17,7 +17,8 @@
// See COPYING file for full licensing terms.
// See COPYING file for full licensing terms.
// See https://www.nexedi.com/licensing for rationale and options.
// See https://www.nexedi.com/licensing for rationale and options.
// Package wks links-in well-known ZODB storages
// Package wks links-in well-known ZODB storages.
//
// The only purpose of this package is so that users could import it
// The only purpose of this package is so that users could import it
//
//
// import _ ".../zodb/wks" XXX fixme import path
// import _ ".../zodb/wks" XXX fixme import path
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment