Thank you, tomorrow i will try it! Do you know if it possible to enable it without changing the enviroment variable? My application is started by another one and i can't (easily) change the enviroment variables. On Tuesday, February 9, 2021 at 8:57:36 PM UTC+1 Uli Kunitz wrote:
> It is GODEBUG=allocfreetrace=1 . Documentation for GODEBUG can be found > here: https://pkg.go.dev/runtime > > On Tuesday, February 9, 2021 at 8:39:27 PM UTC+1 Uli Kunitz wrote: > >> GODEBUG=allocfreetrace may be what you are looking for. You might want >> to check the output with sort | uniq -c. >> >> On Tuesday, February 9, 2021 at 8:05:23 PM UTC+1 Miles Hex wrote: >> >>> >>> Hi, >>> >>> I'm using golang (1.15.6) to write a daemon that handle system >>> task(network, time, updates, etc..) in embedded device (an onion omega >>> 2+), and i'm encountering a small memory leak that i'm unable to identify >>> and fix. >>> The device is using linux 4.14.171, the architecture is mips. >>> >>> At first i used "go tool pprof" and the memory profile but the "inuse" >>> index is always empty, and that kinda match my expectation since the >>> application spend most of his time idle awaiting commands/event (i must add >>> that he leak occur even when the application is idle). I also checked the >>> number of goroutine that remains constant. >>> >>> I then added some logs to try to understand when this allocation occurs >>> (and the subsequent leak), but i'm unable to make sense of the data. >>> I also collected a couple of heapdump that i'm trying to analyze with >>> "github.com/temorfeouz/heapdump14" (which is a fork of >>> https://github.com/randall77/heapdump14, and the only tool i find that >>> can open heapdump of go 1.15) >>> >>> Following is the (partial) memstat data: >>> >>> MemStast Before: >>> "HeapAlloc": 1811448, >>> "HeapSys": 7176192, >>> "HeapIdle": 4399104, >>> "HeapInuse": 2777088, >>> "HeapReleased": 3358720, >>> "HeapObjects": 11200, >>> "StackInuse": 1212416, >>> "StackSys": 1212416, >>> >>> MemStat After 7 days: >>> "HeapAlloc": 2033048, >>> "HeapSys": 11403264, >>> "HeapIdle": 8257536, >>> "HeapInuse": 3145728, >>> "HeapReleased": 8257536, >>> "HeapObjects": 13060, >>> "StackInuse": 1179648, >>> "StackSys": 1179648, >>> >>> I also have the summary from the two heapdump >>> Before: >>> Heap size: 8.0 MB bytes >>> Heap live: 1.8 MB bytes >>> Heap objects: 11496 >>> Reachable objects: 10492 >>> Reachable size: 1.6 MB bytes >>> >>> After 7 days: >>> Heap size: 12.0 MB bytes >>> Heap live: 2.0 MB bytes >>> Heap objects: 13198 >>> Reachable objects: 10454 >>> Reachable size: 1.6 MB bytes >>> >>> I have collected a lot more data, including all the profile made >>> available from the go runtime and various system information. >>> >>> If i'm reading this data correctly there is a memory leak as the heap si >>> growing but i'm not sure how to find it! I tough i could try to diff the >>> two heapdump with excel but the tool that i'm using is not very "precise" >>> and a lot of type information seem to be lost. >>> >>> I don't know how to make sense of this data, what would your next step? >>> I'm quite new in the golang ecosystem and i'm unsure how to move from here. >>> >>> Thanks. >>> >>> >>> >>> >>> >>> -- You received this message because you are subscribed to the Google Groups "golang-nuts" group. To unsubscribe from this group and stop receiving emails from it, send an email to golang-nuts+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/golang-nuts/9da32c39-c01b-4bf7-94bc-10894963658fn%40googlegroups.com.