Skip to content
GitLab
Projects
Groups
Snippets
/
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
Open sidebar
Vladimir Barsukov
zGo
Commits
41f388bf
Commit
41f388bf
authored
Nov 19, 2023
by
Vladimir Barsukov
Browse files
fix
parent
c76eb20c
Changes
1
Hide whitespace changes
Inline
Side-by-side
zdebug/zdebug.go
View file @
41f388bf
...
...
@@ -2,7 +2,6 @@ package zdebug
import
(
"fmt"
"git.barsukov.pro/barsukov/zgo/zjson"
"git.barsukov.pro/barsukov/zgo/zutils"
"runtime"
"strings"
...
...
@@ -10,32 +9,39 @@ import (
)
type
Monitor
struct
{
Alloc
,
Sys
,
LiveObjects
uint64
Alloc
uint64
`json:",omitempty"`
HeapInuse
uint64
`json:",omitempty"`
MaxAlloc
uint64
`json:",omitempty"`
MaxSys
uint64
`json:",omitempty"`
NumGC
uint32
NumGoroutine
int
LiveObjects
uint64
`json:",omitempty"`
NumGC
uint32
`json:",omitempty"`
NumGoroutine
int
`json:",omitempty"`
}
const
mb
=
1024
*
1024
func
NewMonitor
(
secs
int
)
{
go
func
()
{
var
m
Monitor
var
rtm
runtime
.
MemStats
var
interval
=
time
.
Duration
(
secs
)
*
time
.
Second
var
memMax
uint64
for
{
<-
time
.
After
(
interval
)
<-
time
.
After
(
time
.
Duration
(
secs
)
*
time
.
Second
)
runtime
.
ReadMemStats
(
&
rtm
)
m
.
NumGoroutine
=
runtime
.
NumGoroutine
()
m
.
Alloc
=
rtm
.
Alloc
/
1e6
m
.
Sys
=
rtm
.
Sys
/
1e6
m
.
LiveObjects
=
rtm
.
Mallocs
-
rtm
.
Frees
m
.
NumGC
=
rtm
.
NumGC
mem
:=
((
rtm
.
HeapIdle
-
rtm
.
HeapReleased
)
+
(
rtm
.
Alloc
+
rtm
.
HeapInuse
))
/
1e6
memMax
=
max
(
memMax
,
mem
)
fmt
.
Println
(
zjson
.
MustString
(
m
))
fmt
.
Printf
(
"Z_DEBUG: MEM: %v; MEM_MAX: %v; OBJ: %v, GO: %v, GC: %v
\n
"
,
mem
,
memMax
,
(
rtm
.
Mallocs
-
rtm
.
Frees
)
/
1e3
,
runtime
.
NumGoroutine
(),
rtm
.
NumGC
,
)
}
}()
}
...
...
Write
Preview
Supports
Markdown
0%
Try again
or
attach a new 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